收录日期:2019/03/27 11:16:41 时间:2016/05/18 06:55:16 标签:基础和管理
今天,看到了一篇文章。出处:http://www.itpub.net/showthread.php?s=e02e8259361eca6e9870354a41793897&threadid=126541
里面谈到了,CBO有时会造成查询速度奇慢。摘录主要内容如下:
很幸运,Ordered提示使Oracle选择了较好的执行计划。 
所以会产生这样的效果,是因为在CBO的执行计划中,对于7张数据表,Oracle需要计算7!(5040)个连接顺序,然后比较各个顺序的成本,最后选择成本较低的执行计划。 
显然,在这一判断上耗费了大量的时间。当我们使用ordered hints的时候,Oracle就不需要这一计算步骤,它只需要使用我们指定的顺序,然后快速的给出结果。然后问题迎刃而解。
3. 初试化参数对于执行计划的影响 
有几个初试化参数对于多表连接的执行计划有重要的关系。 

在Oracle 8 release 8.0.5中引入了两个参数OPTIMIZER_MAX_PERMUTATIONS 和 OPTIMIZER_SEARCH_LIMIT 

optimizer_search_limit参数指定了在决定连接多个数据表的最好方式时,CBO需要衡量的数据表连接组合的最大数目。 
该参数的缺省值是5。 
如果连接表的数目小于optimizer_search_limit参数,那么Oracle会执行所有可能的连接。可能连接的组合数目是数据表数目的阶乘。 

我们刚才有7张表,那么有7!(5040)种组合。 

optimizer_max_permutations参数定义了CBO所考虑的连接排列的最大数目的上限。 
当我们给这个参数设置很小的一个值的时候,Oracle的计算比较很快就可以被遏制。然后执行计划,给出结果。 

optimizer_search_limit参数和optimizer_max_permutations参数和Ordered参数不相容,如果定义了ordered提示,那么optimizer_max_permutations参数将会失效。 
实际上,当你定义了ordered提示时,oracle已经无需计算了。

在有的系统视图查询中,很多时候会出现问题,比如以下的SQL: 


select a.username, a.sid, a.serial#, b.id1 
from v$session a, v$lock b 
where a.lockwait = b.kaddr 


这个语句用来查找锁,在Oracle7的年代,这样的SQL语句执行的很快,但是在Oracle8以后的数据库,如果碰巧你用的是CBO,那么这样的语句执行结果可能是Hang了(其实不是死了,只是很多人没有耐心等而已),在Oracle7里,这样的语句毫无疑问使用RBO,很快你就可以得到执行结果。可以对于CBO,你所看到的两个视图,对于数据库来说,实际上是6个表,单只6个表的可能顺序组合就有6!(720)种,数据库时间都消耗在计算这些执行路径上了,所以你得到的就是hang的结果。 
最简单的解决办法就是使用rule提示,或者使用ordered提示

看来,自ORACLE8后,ORACLE增加了很多面向最终用户的特性,目的能够尽可能地降低管理的难度,可以,自然也会带来一些负面的影响。我想,同样的在SQLServer2000等中应该一样存在。
欢迎大家讨论!!!!
如果有一句非常复杂的语句,如a join b join c join d join e join f join g
是不是改换成(((((a join b) ab join c) abc join d ) abcd join e) abcde join f )join g 要好很多呢?因为,我为它指定了一条执行计划的路径。
CBO 是一把双面刃,我个人觉得除非对于每个SQL都做过测试,否则对CBO一定要谨慎。
在ORACLE7的版本中,有时,一个SQL 会因为CBO而变得无限费时!!!!
在一般的情况中,cbo是能提高查询速度的,
但是在8i中,9i对优化器又有了进一步处理,cbo难免有判断错误的地方,这样就导致了本是rbo的语句,却使用了cbo。
如我们一直提倡的bind变量,都可能引起优化器的错误判断。
对于部分语句,除了hint提示外,还可以用outline来解决问题。
所以oracle见意8i前的用RBO,8i及8i以后的用CBO
说一句题外话,9i里面绑定变量已经不影响cbo的路径选择了
看来9i注意到了8i中存在的问题了。

FlashMX数据库操作完全攻略-上部-第5卷 关于CWnd简单的问题请教各位大侠[100分] 帮我看看两表相关联的查询,怎么会出错?再次,还有没有其它的查询办法?以前用ASP写过,现在搞忘记了。谢谢!!! 错在哪里啊 怎样把一个Recordset的数据全部写入一个表中? c# Builder不好用,建议改用VS.net+ Visual UML 3.0开发系统。 TreeView 控件的使用问题,一旦答上立即给分! 急,在线等!!!! 请大家帮忙看一下,药品费用查询SQL语句是否可以这样写? 请问大虾们。在AUTHORWARE里怎么把外框去掉。 jsp中的中文问题??? 急,急,!FREEbsdunix下的程序问题! VAX II机的VMS操作系统如何与486的DOS系统相连 如何提取指定文件夹内后缀为 .htm 的所有文件名? 请大家帮忙看一下,在院病人费用查询SQL语句是否可以这样写? 请各位高手帮忙,谢谢!! 和一条妞分了,她不爱我,我不爱她, 不小心把Bios修改项禁用了,请问怎么能够恢复从前的样子?谢谢! 请大家帮忙看一下,门诊费用查询SQL语句是否可以这样写? 帮忙检查一下,函数无法执行 mysql++是什么东西啊?不好意思,本人对于mysql不熟悉,可能问了个很菜的问题 gif 默认的打开类型 是什么? 如何求某个组件中子组件的个数 请教!关于java版本的兼容问题!高分!急,在线等待! 想列出所有User的权限,怎么写Sql?? (在线!) c#中,如何将ascII 34 转换为字符? 求一段JS文件 EMSMySqlManager有linux版本的吗? 有关pchar类型 php3 移到php4下,,不能接收form,,有没有配置方法,,按原来的程序运行?