日期:2014-05-16  浏览次数:20651 次

oracle_执行计划_谓词信息和数据获取

?

oracle_执行计划_谓词信息和数据获取()

一:简要说明

在查看执行计划的信息中,经常会看到两个谓词filteraccess,它们的区别是什么,理解了这两个词对我们解读Oracle的执行计划信息会有所帮助。

简单说,执行计划如果显示是access,就表示这个谓词条件的值将会影响数据的访问路径(表还是索引),而filter表示谓词条件的值并不会影响数据访问路径,只起到过滤的作用。

?

二:举例说明

?

C:\Documents and Settings\Administrator>sqlplus /nolog
SQL*Plus: Release 10.2.0.1.0 - Production on 星期一 12月 26 10:17:27 2011
Copyright (c) 1982, 2005, Oracle.  All rights reserved.
SQL> conn haec0/test@HATEST
已连接。
SQL> create table zhou_t (x int , y int );
表已创建。
SQL> set autotrace trace exp;
SQL> select /*+rule*/ * from zhou_t where x=5;
执行计划
----------------------
Plan hash value: 1395150869
------------------------------------
| Id  | Operation         | Name   |
------------------------------------
|   0 | SELECT STATEMENT  |        |
|*  1 |  TABLE ACCESS FULL| ZHOU_T |
------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
   1 - filter("X"=5)
Note
-----
-          rule based optimizer used (consider using cbo)
??

因为表zhou_t没有创建索引,执行计划没有选择数据访问路径的余地,谓词条件在这里只是起到数据过滤的作用,所以使用了filter

如果在表上创建了索引呢?下面来看看:

?

?

SQL> create index zhou_t_idx on zhou_t(x,y);
索引已创建。
SQL> select /*+rule*/ * from zhou_t where x=5;
执行计划
----------------------
Plan hash value: 42197324
---------------------------------------
| Id  | Operation        | Name       |
---------------------------------------
|   0 | SELECT STATEMENT |            |
|*  1 |  INDEX RANGE SCAN| ZHOU_T_IDX |
---------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
   1 - access("X"=5)
Note
-----
-          rule based optimizer used (consider using cbo)
?

从上面可以看到,谓词条件影响到数据访问的路径------选择了索引,所以用access