ORDERED提示强制Oracle按照From子句中表出现的顺序进行表连接。
通过ordered提示,可以避免CBO SQL解析过程中的表连接评估,从而避免Oracle产生错误的执行计划,或者强制Oracle按照我们指定的方式执行。
在很多时候,当我们清楚地了解数据结构和数据分布之后,就可以通过ORDERED提示来提高SQL性能。
通过以下例子我们来说明一下Ordered提示的作用.
1.不加Hints时SQL的执行计划
我们可以通过10053事件跟踪一下该SQL的解析:
查看Trace文件可以看到,Oracle需要进行3! (6)次表连接顺序的评估:
2.当我们使用Ordered提示之后
SQL的执行计划如下(from子句后的表顺序作了调整):
再看10053的跟踪Trace文件:
Oracle只需要按照表在From子句中的出现顺序进行连接,从而按照我们的意图进行解析或执行.
这就是Ordered提示的基本作用,本例只是一个示范说明,后者的执行计划使得Cost激增,在实际应用中,我们当然是不希望看到此类增长的.
转载于:https://blog.51cto.com/19880614/1251145