Oracle语句优化53个规则详解(7)
来源:互联网 发布:博拉网络加班 编辑:程序博客网 时间:2024/06/06 03:26
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的记录。
- Oracle语句优化53个规则详解
- Oracle语句优化53个规则详解
- Oracle语句优化53个规则详解
- Oracle语句优化53个规则详解
- Oracle语句优化53个规则详解
- Oracle语句优化53个规则详解
- Oracle语句优化53个规则详解
- Oracle语句优化53个规则详解
- Oracle语句优化53个规则详解
- Oracle语句优化53个规则详解
- Oracle语句优化53个规则详解
- Oracle语句优化53个规则详解
- Oracle语句优化53个规则详解(7)
- Oracle语句优化30个规则详解
- Oracle语句优化30个规则详解
- 30个Oracle语句优化规则详解
- 30个Oracle语句优化规则详解
- 30个Oracle语句优化规则详解
- Dreamweaver中编写CSS的要领
- 010 Editor v3.0 with Patch&Keygen by Velaw/TSRh
- 做part-time小网站不要使用Java语言
- Concept-第20章翻译
- SQL server 导入数据
- Oracle语句优化53个规则详解(7)
- C#数据绑定
- ASP无限分类变数组
- 什么是MCML?
- C#正则表达式小结
- Cannot load C:/php/php5apache2.dll into server[转]
- Oracle语句优化53个规则详解(8)
- 掌握SQL四条最基本的数据操作语句:Insert,Select,Update和Delete
- Oracle语句优化53个规则详解(9)