`

oracle Optimizer CBO RBO (优化器)

 
阅读更多

 

Oracle 的优化器有两种:


RBO(Rule-BasedOptimization): 基于规则的优化器

CBO(Cost-BasedOptimization): 基于代价的优化器


CBO在ORACLE7 引入,但在ORACLE8i 中才成熟。ORACLE 已经明确声明在ORACLE9i之后的版本中(ORACLE 10G ),RBO将不再支持。因此选择CBO 是必然的趋势。但是我们依然可以通过Hint 方式来使用它。


Oracle 数据库中优化器(Optimizer)是SQL分析和执行的优化工具,它负责指定SQL的执行计划,也就是它负责保证SQL执行的效率最高,比如优化器决定Oracle以什么样的方式来访问数据,是全表扫描(Full Table Scan),索引范围扫描(Index Range Scan)还是全索引快速扫描(INDEX Fast Full Scan:INDEX_FFS);对于表关联查询,它负责确定表之间以一种什么方式来关联,比如HASH_JOHN还是NESTED LOOPS 或者MERGE JOIN。 这些因素直接决定SQL的执行效率,所以优化器是SQL 执行的核心,它做出的执行计划好坏,直接决定着SQL的执行效率。


一.RBO 基于规则的优化器

在8i之前,Oracle 使用的是一种叫作RBO(Rule Based Optimizer)的优化器,它的执行机制非常简单,就是在优化器里面嵌入若干种规则,执行的SQL语句符合哪种规则(RANK),则按照规则(RANK)制定出相应的执行计划,比如说表上有个索引,如果谓词上有索引的列存在,则Oracle 会选择索引,否则选择全表扫描;又比如,两个表关联的时候,按照表在SQL中的位置来决定哪个是驱动表,哪个是被驱动表。


由于RBO 只是简单的去匹配Rank,所以它的执行计划有时并不是最佳的。 比如我们有一张数据分布非常不均匀的表。 90%的数据内容是一样的,并且在这个字段上有索引。 如果我们的SQL 谓词里有这个字段,那么RBO 就会选择走索引。 这就会增加额外的开销。 因为Oracle 要先访问索引数据块,在索引上找到相应的键值,然后按照键值上的rowid 在去访问表中的相应数据。 在这种情况下,我们选择全表扫描是最优的,但是RBO 不会这么选择。


二.CBO 基于成本的优化器


从8i开始,Oracle 引入了CBO(Cost Based Optimizer),它的思路是让Oracle 获取所有执行计划相关的信息,通过对这些信息做计算分析,最后得出一个代价最小的执行计划作为最终的执行计划。


CBO是一种比RBO 更理性化的优化器。从10g开始,Oracle 已经彻底丢弃了RBO。 即使在表,索引没有被分析的时候,Oracle依然会使用CBO。此时,Oracle 会使用一种叫做动态采样的技术,在分析SQL的时候,动态的收集表,索引上的一些数据块,使用这些数据块的信息及字典表中关于这些对象的信息来计算出执行计划的代价,从而挑出最优的执行计划。


当表没有做分析的时候,Oracle 会使用动态采样来收集统计信息,这个动作只有在SQL执行的第一次,即硬分析阶段使用,后续的软分析将不在使用动态采样,直接使用第一次SQL 硬分析时生成的执行计划。


在Oracle 10g中,CBO 可选的运行模式有2种:

(1)       FIRST_ROWS(n)

(2)       ALL_ROWS  -- 10g中的默认值


查看CBO 模式:


SQL> show parameter optimizer_mode 

NAME                                 TYPE        VALUE

-----------------------------------------  -------------

optimizer_mode               string      ALL_ROWS


修改CBO 模式的三种方法:


(1)SQL 语句:

  Sessions级别:

  SQL> alter session setoptimizer_mode=all_rows;


(2) 修改pfile 参数:

OPTIMIZER_MODE=RULE/CHOOSE/FIRST_ROWS/ALL_ROWS


(3) 语句级别用Hint(/* +  ...  */)来设定

  Select /*+ first_rows(10) */ name from table;

  Select/*+ all_rows */ name from table;  


OPTIMIZER_INDEX_COST_ADJ参数

参数OPTIMIZER_INDEX_COST_ADJ可以理解为Oracle执行多块(MultiBlock)I/O(比如全表扫描)的代价与执行单块(Single-block)I/O代价的相对比例。OPTIMIZER_INDEX_COST_ADJ通过指明索引I/O代价与扫描全表I/O代价的相对比值来影响CBO的行为,取值越小,CBO越倾向于使用索引,取值越大,越倾向于全表扫描。而缺省值100,指明缺省下,二者的代价是相等。


FIRST_ROWS(n) 模式说明

当CBO 的优化模式设置为FIRST_ROWS(n)时,Oracle 在执行SQL时,优先考虑将结果集中的前n条记录以最快的速度反馈回来,而其他的结果并不需要同时返回。


这种需求在一些网站或者BBS的分页上经常看到,比如每次只显示查询信息的前20条或者BBS上的前20个帖子, 这时候设置FIRST_ROWS(20)就非常合适,优化器并不需要同事将所有符合条件的结果返回,用户也不需要。这时,CBO将考虑用一种最快的返回前20条记录的执行计划,这种执行计划对于SQL的整体执行时间也不不是最快的,但是在返回前20条记录的处理上,确实最快的。


ALL_ROWS 模式说明

当CBO 模式设置为ALL_ROWS时,Oracle 会用最快的速度将SQL执行完毕,将结果集全部返回,它和FIRST_ROWS(n)的区别在于,ALL_ROWS强调以最快的速度将SQL执行完毕,并将所有的结果集反馈回来,而FIRST_ROWS(n)则侧重于返回前n条记录的执行时间。


ALL_ROWS在OLAP 系统中使用得比较多,它用最快的速度获得SQL执行的最后一条记录,而不是前N条记录。 和FIRST_ROWS(n)正好相反。 ALL_ROWS 强调SQL整体的执行效率,而FIRST_ROWS(n)强调用最快的速度返回前N行,而不管所有的结果返回的时长,可能最后一条要很长时间才能获得。


具体什么时候使用RBO,什么时候强制使用RBO,可以查看:

 http://blog.csdn.net/suncrafted/article/details/4239237

 http://blog.csdn.net/suncrafted/article/details/4239148

分享到:
评论

相关推荐

    CBO,RBO在ORACLE中的应用

    CBO自Oracle 7引入,但在Oracle 8i时达到成熟,并在Oracle 9i及以后的版本中逐渐取代RBO成为主要的优化器。RBO基于固定的规则来生成执行计划,而CBO则通过评估各种可能执行计划的成本来选择最佳方案。 CBO的主要...

    Oracle的优化器(Optimizer)

    ### Oracle的优化器(Optimizer)详解 #### 一、Oracle优化器概述 在Oracle数据库中,每当执行SQL语句时,系统首先需要确定最佳的执行路径或计划,这一过程由**优化器(Optimizer)**负责。优化器的主要任务是评估SQL...

    Oracle的RBO和CBO详细介绍和优化模式设置方法

    优化器主要有两种策略:基于规则的优化(RBO)和基于代价的优化(CBO)。理解这两种优化方式以及如何设置优化模式对于数据库管理员和开发人员来说至关重要。 **RBO(基于规则的优化)**: RBO是早期Oracle版本中...

    Oracle optimizer性能优化手册 chm

    这本书涵盖了Oracle优化器的工作原理、如何分析和调整优化器的行为,以及如何通过各种手段提升数据库性能。 1. **Oracle Optimizer工作原理**: Oracle Optimizer通过统计信息、成本估算和执行策略来确定最佳执行...

    Oracle9i优化器介绍

    Oracle9i包含两种主要的优化器:成本基于(Cost-Based Optimizer, CBO)和规则基于(Rule-Based Optimizer, RBO)。CBO是默认的优化器,它通过估算不同执行计划的成本来决定最佳路径,而RBO则依赖于预定义的规则和...

    oracle9i优化器介绍

    ### Oracle9i优化器深入解析 #### 一、优化器目标的选择 在Oracle9i数据库系统中,优化器的目标选择至关重要,它直接影响着查询的执行效率。优化器目标主要分为两类:最佳吞吐量(All_Rows)和最快响应速度(First...

    Oracle语句优化53个规则详解

    - **配置优化器**:可以通过初始化参数`OPTIMIZER_MODE`来设置默认的优化器模式,该参数支持的值包括`RULE`、`COST`、`CHOOSE`、`ALL_ROWS`和`FIRST_ROWS`等。可以在`init.ora`文件中设置或通过会话级命令进行覆盖。...

    Oracle DB优化总结

    1. **基于成本的优化器(Cost-Based Optimizer, CBO)**:这是Oracle默认的优化器,它根据统计信息估算各个执行计划的成本,然后选择成本最低的执行计划。成本包括I/O操作、CPU计算等。 2. **基于规则的优化器...

    【oracle】oracle查询优化改写

    Oracle有多种优化器,如RBO(Rule-Based Optimizer,基于规则的优化器)和CBO(Cost-Based Optimizer,基于成本的优化器)。CBO是现代Oracle数据库的默认优化器,它通过估算不同执行计划的成本来选择最优路径。这个...

    Oracle优化器介绍(精简完善版).doc

    Oracle优化器经历了从基于规则的优化器(RBO)到基于成本的优化器(CBO)的演变,这一转变显著提升了性能优化能力。 #### RBO与CBO对比 **RBO (Rule-Based Optimizer)**是一种早期的优化技术,它依据预定义的规则集来...

    平安Oracle CBO 资料.doc

    与基于规则的优化器(RBO,Rule-Based Optimizer)相比,CBO能够更准确地评估查询成本,从而提高数据库性能和响应速度。 #### 二、CBO统计信息收集策略 平安集团明确指出了CBO统计信息收集的策略,强调了其重要性...

    ORACLE存储过程性能优化技巧

    - **基本原理**:RBO优化器的工作原理是根据一系列预定义的规则来决定SQL语句的执行计划。这些规则通常反映了SQL语句执行的一般行为模式,比如索引使用、表扫描等。 - **规则优先级**:RBO按照规则号的大小顺序来...

    Oracle中SQL优化器的两种优化方式及使用.pdf

    本文主要介绍Oracle中SQL优化器的两种优化方式:基于规则的优化器(Rule-Based Optimizer, RBO)和基于成本的优化器(Cost-Based Optimizer, CBO),以及这两种方式在实际应用中的具体使用。 一、分析SQL语句的执行过程...

    Oracle实战优化器

    优化器根据不同的策略可以分为两种类型:基于规则的优化器(Rule Based Optimizer, RBO)和基于成本的优化器(Cost Based Optimizer, CBO)。这两种优化器的选择和使用直接影响了SQL语句的性能表现。 #### 二、基于规则...

    oracle性能优化之SQL语句优化

    自Oracle 7开始,CBO成为了主要的优化器,并在后续版本中逐渐取代了RBO,因为CBO能更好地适应复杂的查询和多变的数据库环境。 在Oracle 9i及之后的版本中,优化器模式可以通过初始化参数`optimizer_mode`进行设置。...

    oracle 优化器介绍

    首先,Oracle 优化器主要有两种类型:基于规则(Rule-Based Optimizer, RBO)和基于成本(Cost-Based Optimizer, CBO)。RBO根据预定义的规则来选择执行计划,而CBO则是Oracle数据库默认的优化器,它基于对查询执行...

    ORACLE数据库中SQL优化解析.pdf

    优化器有两种类型:基于规则的优化器(RBO)和基于代价的优化器(CBO)。RBO主要根据预定义的规则进行优化决策,而CBO则根据统计信息来评估不同执行路径的成本,进而选择成本最低的执行路径。由于RBO的局限性,...

    Oracle数据库优化详解

    本文针对Oracle数据库的优化提供了详尽的指导和案例分析,尤其强调了在CBO(Cost-Based Optimizer,基于成本的优化器)模式下的优化方法。 首先,Oracle数据库优化不仅仅是技术问题,它还涉及到策略问题。在1992年...

Global site tag (gtag.js) - Google Analytics