oracle_执行计划_谓词信息和数据获取(上)
一:简要说明
在查看执行计划的信息中,经常会看到两个谓词filter和access,它们的区别是什么,理解了这两个词对我们解读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