oracle_执行计划_谓词信息和数据获取
oracle_执行计划_谓词信息和数据获取(上)
一:简要说明
在查看执行计划的信息中,经常会看到两个谓词filter和access,它们的区别是什么,理解了这两个词对我们解读Oracle的执行计划信息会有所帮助。
简单说,执行计划如果显示是access,就表示这个谓词条件的值将会影响数据的访问路径(表还是索引),而filter表示谓词条件的值并不会影响数据访问路径,只起到过滤的作用。
二:举例说明
C:\Documents and Settings\Administrator>sqlplus /nologSQL*Plus: Release 10.2.0.1.0 - Production on 星期一 12月 26 10:17:27 2011Copyright (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
页:
[1]