您的位置:首页 > 数据库 > Oracle

Oracle技术之如何使用ordered提示改变SQL执行计划

2013-07-17 09:47 1116 查看
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激增,在实际应用中,我们当然是不希望看到此类增长的.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息