打印本文 打印本文 关闭窗口 关闭窗口
ORACLE SQL性能优化系列 (十)
作者:武汉SEO闵涛  文章来源:敏韬网  点击数2512  更新时间:2009/4/22 22:08:11  文章录入:mintao  责任编辑:mintao
34.       避免在索引列上使用NOT

通常, 我们要避免在索引列上使用NOT, NOT会产生在和在索引列上使用函数相同的

影响. 当ORACLE”遇到”NOT,他就会停止使用索引转而执行全表扫描.

   举例:

 

   低效: (这里,不使用索引)

 

   SELECT …

   FROM DEPT

   WHERE DEPT_CODE NOT = 0;

  

   高效: (这里,使用了索引)

 

  SELECT …

   FROM DEPT

   WHERE DEPT_CODE > 0;

 

   需要注意的是,在某些时候, ORACLE优化器会自动将NOT转化成相对应的关系操作符.

   NOT >  to  <=

   NOT >=  to  <

   NOT <  to  >=

   NOT <=  to  >

 

 

译者按:

     在这个例子中,作者犯了一些错误. 例子中的低效率SQL是不能被执行的.

我做了一些测试:

    

SQL> select * from emp where NOT empno > 1;

no rows selected

Execution Plan

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

   0      SELECT STATEMENT Optimizer=CHOOSE

   1    0   TABLE ACCESS (BY INDEX ROWID) OF ''''EMP''''

   2    1     INDEX (RANGE SCAN) OF ''''EMPNO'''' (UNIQUE)    

 

SQL> select * from emp where empno <= 1;

no rows selected

Execution Plan

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

   0      SELECT STATEMENT Optimizer=CHOOSE

   1    0   TABLE ACCESS (BY INDEX ROWID) OF ''''EMP''''

   2    1     INDEX (RANGE SCAN) OF ''''EMPNO'''' (UNIQUE)

 

      两者的效率完全一样,也许这符合作者关于” 在某些时候, ORACLE优化器会自动将NOT转化成相对应的关系操作符” 的观点.

     

35.       用>=替代>

 

如果DEPTNO上有一个索引,

 

高效:

 

   SELECT *

   FROM EMP

   WHERE DEPTNO >=4

  

   低效:

上一页  [1] [2] [3]  下一页

打印本文 打印本文 关闭窗口 关闭窗口