周凡杨 发表于 2013-1-29 15:20:30

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]
查看完整版本: oracle_执行计划_谓词信息和数据获取