`
nenty
  • 浏览: 113127 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Oracle语句优化规则汇总(2)

    博客分类:
  • sql
阅读更多
ORACLE采用自下而上的顺序解析WHERE子句,根据这个原理,表之间的连接必须写在其他WHERE条件之前, 那些可以过滤掉最大数量记录的条件必须写在WHERE子句的末尾。
  例如:
  (低效,执行时间156.3秒)
  SELECT …
  FROM EMP E
  WHERE SAL > 50000
  AND JOB = ‘MANAGER’
  AND 25 < (SELECT COUNT(*) FROM EMP
  WHERE MGR=E.EMPNO);
  (高效,执行时间10.6秒)
  SELECT …
  FROM EMP E
  WHERE 25 < (SELECT COUNT(*) FROM EMP
  WHERE MGR=E.EMPNO)
  AND SAL > 50000
  AND JOB = ‘MANAGER’;
  2. SELECT子句中避免使用 ‘ * ’
  当你想在SELECT子句中列出所有的COLUMN时,使用动态SQL列引用 ‘*’ 是一个方便的方法。不幸的是,这是一个非常低效的方法。 实际上,ORACLE在解析的过程中, 会将‘*’ 依次转换成所有的列名, 这个工作是通过查询数据字典完成的, 这意味着将耗费更多的时间。
  3. 减少访问数据库的次数
  当执行每条SQL语句时, ORACLE在内部执行了许多工作: 解析SQL语句, 估算索引的利用率, 绑定变量 , 读数据块等等。 由此可见, 减少访问数据库的次数 , 就能实际上减少ORACLE的工作量。
  例如,以下有三种方法可以检索出雇员号等于0342或0291的职员。
  方法1 (最低效)
  SELECT EMP_NAME , SALARY , GRADE
  FROM EMP
  WHERE EMP_NO = 342;
  SELECT EMP_NAME , SALARY , GRADE
  FROM EMP
  WHERE EMP_NO = 291;
方法2 (次低效)
  DECLARE
  CURSOR C1 (E_NO NUMBER) IS
  SELECT EMP_NAME,SALARY,GRADE
  FROM EMP
  WHERE EMP_NO = E_NO;
  BEGIN
  OPEN C1(342);
  FETCH C1 INTO …,..,.. ;
  OPEN C1(291);
  FETCH C1 INTO …,..,.. ;
  CLOSE C1;
  END;
  方法3 (高效)
以下是引用片段:
  SELECT A.EMP_NAME , A.SALARY , A.GRADE,
  B.EMP_NAME , B.SALARY , B.GRADE
  FROM EMP A,EMP B
  WHERE A.EMP_NO = 342
  AND B.EMP_NO = 291;
  注意:
  在SQL*Plus , SQL*Forms和Pro*C中重新设置ARRAYSIZE参数, 可以增加每次数据库访问的检索数据量 ,建议值为200.
  4. 使用DECODE函数来减少处理时间
  使用DECODE函数可以避免重复扫描相同记录或重复连接相同的表。
  例如:
  SELECT COUNT(*),SUM(SAL)
  FROM EMP
  WHERE DEPT_NO = 0020
  AND ENAME LIKE ‘SMITH%’;
  SELECT COUNT(*),SUM(SAL)
  FROM EMP
  WHERE DEPT_NO = 0030
  AND ENAME LIKE ‘SMITH%’;
  你可以用DECODE函数高效地得到相同结果
  SELECT COUNT(DECODE(DEPT_NO,0020,’X’,NULL)) D0020_COUNT,
  COUNT(DECODE(DEPT_NO,0030,’X’,NULL)) D0030_COUNT,
  SUM(DECODE(DEPT_NO,0020,SAL,NULL)) D0020_SAL,
  SUM(DECODE(DEPT_NO,0030,SAL,NULL)) D0030_SAL
  FROM EMP WHERE ENAME LIKE ‘SMITH%’;
  类似的,DECODE函数也可以运用于GROUP BY 和ORDER BY子句中。
  5. 整合简单,无关联的数据库访问
  如果你有几个简单的数据库查询语句,你可以把它们整合到一个查询中(即使它们之间没有关系)
  例如:
  SELECT NAME
  FROM EMP
  WHERE EMP_NO = 1234;
  SELECT NAME
  FROM DPT
  WHERE DPT_NO = 10 ;
  SELECT NAME
  FROM CAT
  WHERE CAT_TYPE = ‘RD’;
  上面的3个查询可以被合并成一个:
  SELECT E.NAME , D.NAME , C.NAME
  FROM CAT C , DPT D , EMP E,DUAL X
  WHERE NVL(‘X’,X.DUMMY) = NVL(‘X’,E.ROWID(+))
  AND NVL(‘X’,X.DUMMY) = NVL(‘X’,D.ROWID(+))
  AND NVL(‘X’,X.DUMMY) = NVL(‘X’,C.ROWID(+))
  AND E.EMP_NO(+) = 1234
  AND D.DEPT_NO(+) = 10
  AND C.CAT_TYPE(+) = ‘RD’;
分享到:
评论

相关推荐

    Oracle语句优化规则汇总.pdf

    这篇文档“Oracle语句优化规则汇总.pdf”很可能提供了关于如何提高Oracle数据库查询效率、减少资源消耗的关键信息。以下是一些可能涵盖在文档中的关键知识点: 1. **索引优化**: - 使用合适的索引类型,如B树索引...

    Oracle语句优化规则汇总

    Oracle数据库是全球广泛使用的...通过遵循这些Oracle语句优化规则,你可以显著提高数据库的性能,减少资源消耗,同时提高应用程序的响应速度。持续学习和实践,结合具体的业务场景,你会发现更多优化的策略和技巧。

    Oracle语句优化规则汇总pdf版最新版本

    以下是对Oracle语句优化规则的总结:

    oracle语句优化规则汇总

    本篇文章将深入探讨Oracle语句优化的若干关键规则,帮助你提升数据库的运行效率,减少资源消耗,提高应用的响应速度。 一、选择正确的索引策略 1. **选择合适的索引类型**:B树索引适用于常规查询,位图索引适合于...

    Oracle sql语句优化规则汇总

    ### Oracle SQL语句优化规则详解 #### 一、选择正确的优化器 在Oracle数据库中,SQL语句的执行效率很大程度上取决于所选的优化器。Oracle提供了三种优化器模式: 1. **基于规则的优化器(RULE)**:这是Oracle...

    oracle语句优化.docx

    "Oracle 语句优化" 本文将详细地介绍 Oracle 语句优化的方法和技巧,涵盖多表关联、EXISTS 和 IN 语句的使用、INDEX_JOIN 优化、WHERE 和 HAVING 语句的区别、NOT IN 和 &lt;&gt; 操作符的使用、LIKE 操作符的替代、UNION...

    Oracle语句优化规则详解【技术文档】

    本文将深入探讨Oracle语句优化的规则和技术,旨在帮助开发者和DBA提升查询效率,降低资源消耗,实现数据库性能的最大化。 一、理解执行计划 Oracle在处理SQL语句时会生成一个执行计划,它定义了数据的检索方式。...

    oracle优化规则总汇

    以下是一些关键的Oracle优化规则: 1. **选用适合的优化器**:Oracle提供了三种优化器:RULE(基于规则)、COST(基于成本)和CHOOSE(选择性)。COST优化器是最常用的一种,它基于对象的统计信息来决定最佳执行...

    oracle查询语句优化

    Oracle查询语句优化是数据库管理中至关重要的环节,能够显著提升系统性能,减少资源消耗。本文将围绕Oracle查询优化的29个小技巧进行深入探讨。 首先,选择合适的Oracle优化器至关重要。Oracle提供了三种优化器:...

    oracle常用SQL语句(汇总版).zip

    本文件"oracle常用SQL语句(汇总版)"将对Oracle中的常用SQL语法进行详尽阐述。 1. 数据查询: - `SELECT`语句:这是SQL中最基本的查询语句,用于从表中检索数据。例如,`SELECT * FROM 表名;`将返回表中的所有记录...

    ORACLE配置文件优化

    6. **Oracle语句优化**:阅读"Oracle语句优化规则汇总.pdf"和"ORACLE-优化.txt"文件,可以学习到如何编写高效的SQL语句,如避免全表扫描,利用索引,减少子查询,以及使用适当的连接方式等。此外,了解并使用Oracle...

Global site tag (gtag.js) - Google Analytics