Oracle CBO知识点

来源:互联网 发布:淘宝点赞买家秀要钱吗 编辑:程序博客网 时间:2024/05/29 16:13

CBO说明(第一部分)

1.    Rule Based OptimizerRBO)基于规则

Cost Based OptimizerCBO)基于成本,或者讲统计信息

 

ORACLE已经明确声明在ORACLE9i之后的版本中(ORACLE 10G )RBO将不再支持。因此选择CBO是必然的趋势。

2.    RBOC BO的差异点:

a)    RBOORACLE 6版以来被采用,有着一套严格的使用规则,只要你按照它去写SQL语句,无论数据表中的内容怎样,也不会影响到你的执行计划,也就是说对数据敏感

b)    CBO计算各种可能执行计划代价,即cost,从中选用cost最低的方案,作为实际运行方案。

执行计划cost的计算根据,依赖于数据表中数据的统计分布,ORACLE数据库本身对该统计分布并不清楚,必须要分析表和相关的索引(使用ANALYZE命令),才能搜集到CBO所需的数据。

c)    使用CBO时,编写SQL语句时,不必考虑"FROM"子句后面的表或视图的顺序和"WHERE"子句后面的条件顺序;

ORACLE7版以来采用的许多新技术都是基于CBO的,如星型连接排列查询,哈希连接查询,函数索引,和并行查询等。

d)    一般而言,CBO所选择的执行计划都不会比RBO执行计划差,而且相对而言,CBO对程序员的要求没有RBO那么苛刻,节省了程序员为了从多个可能的执行计划中选择一个最优的方案而花费的调试时间,但在某些场合下也会存在问题。

3.    如果一个语句使用RBO的执行计划确实比CBO好,则可以通过加" rule"提示,强制使用RBO

4.    使用CBO时,SQL语句"FROM"子句后面的表,必须全部使用ANALYZE命令分析过,如果"FROM"子句后面的是视图,则此视图的基础表,也必须全部使用ANALYZE命令分析过;否则,ORACLE会在执行此SQL语句之前,自动进行ANALYZE命令分析,这会极大导致SQL语句执行极其缓慢。

[全部使用ANALYZE命令分析过]指的是统计分析的结果表针对于all_tables该表的记录值不为空因表从未做统计分析或统计分析被删除时,all_tables表针对要操作表的记录值为空。

 

5.    使用CBO时,SQL语句"FROM"子句后面的表的个数不宜太多,因为CBO在选择表连接顺序时,会对"FROM"子句后面的表进行阶乘运算,选择最好的一个连接顺序。假如"FROM"子句后有6个表,则其可选择的连接顺序就是6*5*4*3*2*1 = 720 种,CBO选择其中一种,而如果"FROM"子句后有12个表,则其可选择的连接顺序就是12*11*10*9*8*7*6*5*4*3*2*1= 479001600 种,如果实在是要访问很多表,则最好使用ORDER提示,强制使用"FROM"子句表固定的访问顺序。

6.  使用CBO时,SQL语句中不能引用系统数据字典表或视图,因为系统数据字典表都未被分析过,可能导致极差的执行计划。但是不要擅自对数据字典表做分析,否则可能导致死锁,或系统性能严重下降。

Oracle CBO知识点(二)

CBO说明(第二部分)

1.     使用CBO 时,要注意看采用了哪种类型的表连接方式。ORACLE的共有Sort Merge JoinSMJ)、Hash JoinHJ)和Nested Loop JoinNL)。CBO有时会偏重于SMJHJ,但在OLTP 系统中,NL 一般会更好,因为它高效的使用了索引。

在两张表连接,且内表的目标列上建有索引时,只有Nested Loop才能有效地利用到该索引。SMJ即使相关列上建有索引,最多只能因索引的存在, 避免数据排序过程。HJ由于须做HASH运算,索引的存在对数据查询速度几乎没有影响。

2.     使用CBO 时,必须保证为表和相关的索引搜集足够的统计数据。

对数据经常有增、删、改的表最好定期对表和索引进行分析,可用SQL语句 “analyze table xxx compute statistics for all indexes;"

ORACLE掌握了充分反映实际的统计数据,才有可能做出正确的选择。

 

3.     使用CBO 时,要注意被索引的字段的值的数据分布,会影响SQL语句的执行计划。

例如:

1)    emp,共有一百万行数据,但其中的emp.deptno列,数据只有4种不同的值,如10203040

虽然emp数据行有很多,ORACLE缺省认定表中列的值是在所有数据行均匀分布的,也就是说每种 deptno值各有25万数据行与之对应。

假设SQL搜索条件DEPTNO=10,利用deptno列上的索引进行数据搜索效率,往往不比全表扫 描的高,ORACLE理所当然对索引视而不见,认为该索引的选择性不高。

2)     另一种情况,如果一百万数据行实际不是在4deptno值间平均分配,其中有99万行对应着值105000行对应值203000行对应值302000行对应值40。在这种数据分布图案中对除值为10外的其它deptno值搜索时,毫无疑问,如果索引能被应用,那么效率会高出很多。

采用对该索引列进行单独分析,或用analyze语句对该列建立直方图,对该列搜集足够的统计数据,使ORACLE在搜索选择性较高的值能用上索引。或是在查询值等于203040SQL中加入索引提示

4.         RBO以表在FROM子句中从右到左的顺序为驱动顺序(Driving Order)

CBO根据由收集到的统计信息而导出的成本,来确定连接顺序(Join Order)。如果没有统计信息,CBO就将以表在FROM子句中从左到右的顺序为驱动顺序(Driving Order),正好和RBO相反。

1)         CBO将结合当前表的高水位信息使用ANALYZE信息。因此,一个语句的执行计划是可能因时间的不同而改变的。

2)         TRUNCATE重置了表的高水位,但是不修改表的统计信息,而是留下了该表的旧的CBO信息。

 

from:http://blog.sina.com.cn/s/blog_7930c09d0100yb89.html

原创粉丝点击