当前位置: 首页 > 面试题库 >

什么时候使用Oracle提示?

薛博赡
2023-03-14
问题内容

我正在对Oracle模式(Oracle版本10)进行一些重构,并且看到了很多使用提示的视图*+ALL_ROWS*/。在其他视图中,还存在其他类型的提示。为什么我应该使用提示?数据库不是基于查询的最佳选择吗?非常感谢!


问题答案:

这是一个很好的问题,但是没有一个单一的答案,因为存在不同类别的提示,不同的提示将适用于这些提示。http://docs.oracle.com/cd/E11882_01/server.112/e16638/hintsref.htm#PFGRF501

ALL_ROWS是一种优化方法,为了清楚地表明您的目标是尽早获取结果集的最后一行而不是第一行,对其进行指定完全有效。在许多情况下,无论如何,优化器都会从查询中推断出这一点,因此它可能是多余的,但您不会通过正确使用它来损害任何东西。

然后有不同的类别,其中一些类别可能被表征为用于测试和探索,例如optimizer_features_enable。可以说,影响连接顺序,访问路径和连接操作的提示属于这种类型,因为有时不建议在应用程序中使用它们。但是,优化器并不完美,并且没有完美的信息,有时它会基于需要校正的不完整信息做出选择。

有些提示无疑是有用且适当的-APPEND可能是最好的示例,因为它是调用直接路径插入的标准方法。

最后,很难对此给出一般性建议。实际上,每个提示都需要在是否应在生产代码中使用的方面得到解决,但是如果您了解优化器并了解您实际考虑的提示以及是否有更好的替代方法(例如,更好的统计信息,不同方法)初始化参数或动态采样(本身就是一个提示)-您将能够进行自己的评估并在遇到挑战时进行辩护。



 类似资料:
  • 问题内容: 奇怪的是: 似乎或多或少被定义为。通过这种方式很容易产生错误: 一些fname意外地以else块结尾。修复很简单,我们应该改用它,但是从表面上看,这似乎是一种不错的pythonic方式,并且比“正确”的方式更具可读性。 由于字符串是不可变的,所以为什么字符串错误是什么技术细节?什么时候进行身份检查更好,什么时候进行平等检查更好? 问题答案: 据我所知,检查对象身份是否相等。由于没有强制

  • 问题内容: 我有一个将客户发送到另一个站点来处理付款的应用程序。客户之外的另一个站点在我们的服务器上调用一个页面,让我们知道付款的状态。被调用页面会检查付款应用程序提供的参数,并检查我们是否知道该交易。然后,它更新数据库以反映状态。这一切都无需与客户进行任何互动即可完成。 我个人选择将此功能实现为JSP,因为将文件拖放到文件系统中比编译和打包文件然后将条目添加到配置文件中要容易得多。 考虑到页面的

  • 问题内容: 我怎么能说: 为什么函数调用中不需要括号,而最后一行呢? 问题答案: 是一个功能 调用该函数并产生该函数返回的任何值。 setTimeout的目的是在一段时间后运行代码。你需要的功能只是传递给它(这样的setTimeout可以自称在适当的时候函数),因为如果你将它传递给setTimeout的前调用的函数(用括号),将执行 现在 而不是1秒后,。

  • 一般来说,当发现 CPU 的占用率和实际业务应该出现的占用率不相符,或者对 Nginx worker 的资源使用率(CPU,内存,磁盘 IO )出现怀疑的情况下,都可以使用火焰图进行抓取。另外,对 CPU 占用率低、吐吞量低的情况也可以使用火焰图的方式排查程序中是否有阻塞调用导致整个架构的吞吐量低下。 常用的火焰图有三种: lj-lua-stacks.sxx 用于绘制 Lua 代码的火焰图 sam

  • 本文向大家介绍什么时候用delegate,什么时候用Notification?相关面试题,主要包含被问及什么时候用delegate,什么时候用Notification?时的应答技巧和注意事项,需要的朋友参考一下 答:delegate针对one-to-one关系,并且reciever可以返回值 给sender,notification 可以针对one-to-one/many/none,recieve

  • 问题内容: 我习惯于进行Java编程,在编程时,您无需真正考虑指针。但是,此刻我正在用C ++编写程序。在创建具有其他类成员的类时,何时应该使用指针,何时不应该使用指针?例如,什么时候我想这样做: 与此相反: 问题答案: 首先避免指针。 在以下情况下使用它们: 您想使用Pimpl习惯用法或抽象工厂。 该实例实际上是由程序的其他部分管理的,而该类仅需要能够访问它。 您想推迟对象的构建(即,您想 在