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

Oracle语句优化53个规则详解

    38.       避免在索引列上使用IS NULL和IS NOT NULL

 避免在索引中使用任何可以为空的列,ORACLE将无法使用该索引。对于单列索引,如果列包含空值,索引中将不存在此记录。 对于复合索引,如果每个列都为空,索引中同样不存在此记录。 如果至少有一个列不为空,则记录存在于索引中。

    举例:

 如果唯一性索引建立在表的A列和B列上, 并且表中存在一条记录的A,B值为(123,null) , ORACLE将不接受下一条具有相同A,B值(123,null)的记录(插入)。 然而如果所有的索引列都为空,ORACLE将认为整个键值为空而空不等于空。 因此你可以插入1000条具有相同键值的记录,当然它们都是空!

    因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引。

    举例:

    低效: (索引失效)

    SELECT …
    FROM DEPARTMENT
 WHERE DEPT_CODE IS NOT NULL;

    高效: (索引有效)

    SELECT …
    FROM DEPARTMENT
 WHERE DEPT_CODE >=0;

 39.       总是使用索引的第一个列

 如果索引是建立在多个列上, 只有在它的第一个列(leading column)被where子句引用时,优化器才会选择使用该索引。

    译者按:这也是一条简单而重要的规则。 见以下实例。

    SQL> create table multiindexusage ( inda number , indb number , descr varchar2(10));
 Table created.
 SQL> create index multindex on multiindexusage(inda,indb);
 Index created.
 SQL> set autotrace traceonly
    SQL> select * from multiindexusage where inda = 1;
 Execution Plan

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

    0      SELECT STATEMENT Optimizer=CHOOSE
 1    0   TABLE ACCESS (BY INDEX ROWID) OF 'MULTIINDEXUSAGE'
 2    1     INDEX (RANGE SCAN) OF 'MULTINDEX' (NON-UNIQUE)

    SQL> select * from multiindexusage where indb = 1;
 Execution Plan

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

    0      SELECT STATEMENT Optimizer=CHOOSE
 1    0   TABLE ACCESS (FULL) OF 'MULTIINDEXUSAGE'

    很明显, 当仅引用索引的第二个列时,优化器使用了全表扫描而忽略了索引

    40.       ORACLE内部操作

 当执行查询时,ORACLE采用了内部的操作。 下表显示了几种重要的内部操作。

ORACLE Clause
内部操作
ORDER BY
SORT ORDER BY
UNION
UNION-ALL
MINUS
MINUS
INTERSECT
INTERSECT
DISTINCT,MINUS,INTERSECT,UNION
SORT UNIQUE
MIN,MAX,COUNT
SORT AGGREGATE
GROUP BY
SORT GROUP BY
ROWNUM
COUNT or COUNT STOPKEY
Queries involving Joins
SORT JOIN,MERGE JOIN,NESTED LOOPS
CONNECT BY
CONNECT BY

    41.       用UNION-ALL 替换UNION ( 如果有可能的话)

    当SQL语句需要UNION两个查询结果集合时,这两个结果集合会以UNION-ALL的方式被合并, 然后在输出最终结果前进行排序。

    如果用UNION ALL替代UNION, 这样排序就不是必要了。 效率就会因此得到提高。

    举例:

 低效:

 SELECT ACCT_NUM, BALANCE_AMT
 FROM DEBIT_TRANSACTIONS
 WHERE TRAN_DATE = ‘31-DEC-95’
 UNION
 SELECT ACCT_NUM, BALANCE_AMT
 FROM DEBIT_TRANSACTIONS
 WHERE TRAN_DATE = ‘31-DEC-95’

 高效:

 SELECT ACCT_NUM, BALANCE_AMT
 FROM DEBIT_TRANSACTIONS
 WHERE TRAN_DATE = ‘31-DEC-95’
 UNION ALL
 SELECT ACCT_NUM, BALANCE_AMT
 FROM DEBIT_TRANSACTIONS
 WHERE TRAN_DATE = ‘31-DEC-95’

    译者按:需要注意的是,UNION ALL 将重复输出两个结果集合中相同记录。 因此各位还是要从业务需求分析使用UNION ALL的可行性。

    UNION 将对结果集合排序,这个操作会使用到SORT_AREA_SIZE这块内存。 对于这块内存的优化也是相当重要的。 下面的SQL可以用来查询排序的消耗量

    Select substr(name,1,25) "Sort Area Name",
 substr(value,1,15)   "Value"
 from v$sysstat
 where name like 'sort%'

 

上一页  [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频道相关导航