通常,当我们将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收集多列统计信息详解