Oracle 11 g收集多列统计信息详解

  

  

通常,当我们将SQL语句提交给甲骨文数据库时,Oracle会选择一种最优方式来执行,这是通过查询优化器查询优化器来实现的.CBO(基于成本的优化器)是甲骨文默认使用的查询优化器模式。在国会预算办公室中,SQL执行计划的生成,是以一种寻找成本(成本)最优为目标导向的执行计划探索过程。所谓成本(成本)就是将CPU和IO消耗整合起来的量化指标,每一个执行计划的成本就是经过优化器内部公式估算出的数字值。
  

  

我们在写SQL语句的时候,经常会碰到哪里子句后面有多个条件的情况,也就是根据多列的条件筛选得到数据。默认情况下,oracle会把多列的选择率(选择性)相乘从而得到的地方语句的选择率,这样有可能造成选择率(选择性)不准确,从而导致优化器做出错误的判断。为了能够让优化器做出准确的判断,从而生成准确的执行计划,oracle 11 g在数据库中引入了收集多列统计信息。本文通过对测试表的多条件查询,介绍收集多列统计信息的重要性。

  

  

我们在Oracle 11 g中进行试验。

        完成;   完成;select * from v $版本;      横幅   --------------------------------------------------------------------------------   Oracle数据库11 g企业版发布11.2.0.3.0——生产   PL/SQL版本11.2.0.3.0——生产   核心11.2.0.3.0生产   TNS Linux:版本11.2.0.3.0 -生产   NLSRTL版本11.2.0.3.0 -生产      完成      

在人力资源用户下创建测试表赫伊,重复插入数据,数据量相当于16个员工表(总行数1712=107 * 16)。

        完成;   完成;康涅狄格州人事/人力资源   连接。   完成;   完成;从员工创建表赫伊select *;      创建表。      完成;从赫伊select count (*);      COUNT (*)   ----------   107      完成;   完成;插入从赫伊赫伊select *;      107行。      完成;/214行。      完成;/428行。      完成;/856行。      完成;提交;      提交完成。      完成;从赫伊select count (*);      COUNT (*)   ----------   1712      完成      

        完成;   完成;exec dbms_stats.gather_table_stats(\“人力资源\”,\“赫伊\”);      PL/SQL过程成功完成。      完成      

        完成;   完成;解释计划的select *赫伊employee_id=110;      解释说。      完成;从表选择* (dbms_xplan.display);      PLAN_TABLE_OUTPUT   --------------------------------------------------------------------------------   计划散列值:774871165      ---------------------------------------------------------------------------   | | |操作Id名称| | |行字节成本(% CPU) | |   ---------------------------------------------------------------------------   SELECT语句| 0 | | | 16 | 1104 | 8 (0)| 00:00:01 |   | * 1 |表访问全部|赫伊| 16 | 1104 | 8 (0)| 00:00:01 |   ---------------------------------------------------------------------------      谓词信息(由操作id):   ---------------------------------------------------      PLAN_TABLE_OUTPUT   --------------------------------------------------------------------------------      1 -过滤器(\“EMPLOYEE_ID \”=110)      13行选择。      完成      

从执行计划可以看出返回了16行记录,结果没有问题。可是,这16个是哪儿来的呢,我们先要了解选择率(选择性)和返回行数是如何计算的:
  

  

选择率(选择性)=在本例中是1/唯一值
  

  

返回行数=选择率(选择性)*表记录总数

  

也就是说,在这个查询语句中,选择率=1/107,返回行数=1/107 * 1712=16

  

<强>
  

        完成;   完成;解释计划的select *赫伊employee_id=110和邮件=\“JCHEN \”;      解释说。      完成;   完成;从表选择* (dbms_xplan.display);      PLAN_TABLE_OUTPUT   --------------------------------------------------------------------------------   计划散列值:774871165      ---------------------------------------------------------------------------   | | |操作Id名称| | |行字节成本(% CPU) | |   ---------------------------------------------------------------------------   SELECT语句| 0 | | | 1 | 69 | 8 (0)| 00:00:01 |   | * 1 |表访问全部|赫伊| 1 | 69 | 8 (0)| 00:00:01 |   ---------------------------------------------------------------------------      谓词信息(由操作id):   ---------------------------------------------------      PLAN_TABLE_OUTPUT   --------------------------------------------------------------------------------      1 -过滤器(\“EMPLOYEE_ID \”=110和\“邮件\”=\ ' JCHEN \ ')      13行选择。      完成

Oracle 11 g收集多列统计信息详解