首页 | 互联网 | IT动态 | IT培训 | Cisco | Windows | Linux | Java | .Net | Oracle | 软件测试 | C/C++ | 嵌入式开发 | 存储世界 | 服务器
网络设备 | IDC | 安全 | 求职招聘 | 数字网校 | 网页设计 | 平面设计 | 技术专题 | 电子书下载 | 教学视频 | 源码下载 | 搜索 | 博客 | 论坛
中国IT实验室Oracle频道
中国IT教育
Google
首页 入门基础 安装配置 体系架构 PLSQL 备份恢复 性能调优 开发技术 资讯动态 考试认证 下载 专题 讨论
您现在的位置: 中国IT实验室 >> Oracle >> 性能调优 >> 正文

Oracle语句优化53个规则详解

    32.       避免在索引列上使用计算。

    WHERE子句中,如果索引列是函数的一部分。优化器将不使用索引而使用全表扫描。

    举例:

    低效:

 SELECT …
    FROM DEPT
WHERE SAL * 12 > 25000;

    高效:

 SELECT …
    FROM DEPT
 WHERE SAL > 25000/12;

    译者按:这是一个非常实用的规则,请务必牢记

    33.       自动选择索引

 如果表中有两个以上(包括两个)索引,其中有一个唯一性索引,而其他是非唯一性。

    在这种情况下,ORACLE将使用唯一性索引而完全忽略非唯一性索引。

    举例:

 SELECT ENAME
 FROM EMP
 WHERE EMPNO = 2326
 AND DEPTNO = 20 ;

    这里,只有EMPNO上的索引是唯一性的,所以EMPNO索引将用来检索记录。

    TABLE ACCESS BY ROWID ON EMP
  INDEX UNIQUE SCAN ON EMP_NO_IDX

    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

    低效:

    SELECT *
 FROM EMP
 WHERE DEPTNO >3

    两者的区别在于, 前者DBMS将直接跳到第一个DEPT等于4的记录而后者将首先定位到DEPTNO=3的记录并且向前扫描到第一个DEPT大于3的记录。

 

上一页  [1] [2] [3] [4] [5] [6] [7] [8] [9] [10]  ... 下一页  >> 

【责编:Peng】

中国IT教育

相关产品和培训
文章评论
 友情推荐链接
 认证培训
 专题推荐

 ·关于Java框架技术专题
 ·XML全攻略技术专题
 ·JAVA开源技术介绍专题
 ·Java嵌入式开发之J2ME技术专题
 ·超前体验 Oracle 11g的5个新特性…
 ·揭密使用VB.NET的五个实用技巧
 ·Oracle和SQL Server常用函数对比专题…
 ·展现C#世界 C#程序设计专题…
 ·Java入门 Tomcat的配置技巧精华专题…
 ·Oracle RMAN物理备份技术详解…
 今日更新
 社区讨论
 博客论点
 频道精选
 Oracle频道相关导航