Oracle 11g新特性之收集多列统计信息(二)

2015-07-16 12:08:48 · 作者: · 浏览: 4


SQL>
从执行计划可以看出返回了1行记录,而事实又是什么样的呢?我们执行一下这条sql语句。



SQL> select count(*) from hoegh where employee_id=110 and email=\'JCHEN\';
?



? COUNT(*)


----------


? ? ? ? 16


SQL>
由此看出,测试表hoegh符合查询条件的数据有16行,而执行计划提示的只有1行,出错了。这是怎么回事呢,也就是我们在开篇提到的选择率(selectivity)出了问题。
在这个多列条件查询语句中,选择率=1/107*1/107,返回行数=1/107*1/107*1712=16/107<1;由于表中存在符合条件的记录,并且返回行数不可能小于1,所以Oracle返回了1。


5.收集多列统计信息,再次查看两个条件的where语句的执行计划


?



SQL>
?
SQL> exec dbms_stats.gather_table_stats(\'HR\',\'HOEGH\',method_opt=>\'for columns(employee_id,email)\');


?


PL/SQL procedure successfully completed.


?


SQL>


SQL> explain plan for select * from hoegh where employee_id=110 and email=\'JCHEN\';


?


Explained.


?


SQL> select * from table(dbms_xplan.display);


?


PLAN_TABLE_OUTPUT


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


Plan hash value: 774871165


?


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


| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |


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


| 0 | SELECT STATEMENT | | 16 | 1152 | 8 (0)| 00:00:01 |


|* 1 | TABLE ACCESS FULL| HOEGH | 16 | 1152 | 8 (0)| 00:00:01 |
---------------------------------------------------------------------------


?


Predicate Information (identified by operation id):


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


?


PLAN_TABLE_OUTPUT


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


?


? 1 - filter(\"EMPLOYEE_ID\"=110 AND \"EMAIL\"=\'JCHEN\')


?


13 rows selected.


?


SQL>


从执行计划的结果来看,同样的一条sql查询语句,在收集多列统计信息后,Oracle的选择率(selectivity)由错变对,这是由于sql语句中的两个条件是有关联的,即employee_id和email在employees表中都是唯一的,都可以唯一标识一行记录;而在收集多列统计信息之前,Oracle并不知道这两个查询条件有关联,所以在计算选择率(selectivity)时,只是简单地采取了相乘的方法。