频道直达 - 专题 - 新闻 - 技巧 - 组网 - 开发 - 安全 - web编程 - 图像 - 操作系统 - 数据库 - 教育 - 旅游 - 健康 - 时尚 - 驱动 - 软件 - 游戏 - 多媒体 - ERP - 讨论组

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

来源:qqread 作者:佚名 出处:巧巧读书 2008-02-19 进入讨论组

     2. 用WHERE替代ORDER BY

  •   ORDER BY 子句只在两种严格的条件下使用索引。
  •   ORDER BY中所有的列必须包含在相同的索引中并保持在索引中的排列顺序。
  •   ORDER BY中所有的列必须定义为非空。
  •   WHERE子句使用的索引和ORDER BY子句中所使用的索引不能并列。

  例如:

  表DEPT包含以下列:

  DEPT_CODE PK NOT NULL
  DEPT_DESC NOT NULL
  DEPT_TYPE NULL

  非唯一性的索引(DEPT_TYPE)

  低效: (索引不被使用)

  SELECT DEPT_CODE
  FROM DEPT
  ORDER BY DEPT_TYPE
  EXPLAIN PLAN:
  SORT ORDER BY
  TABLE ACCESS FULL

  高效: (使用索引)

  SELECT DEPT_CODE
  FROM DEPT
  WHERE DEPT_TYPE > 0
  EXPLAIN PLAN:
  TABLE ACCESS BY ROWID ON EMP
  INDEX RANGE SCAN ON DEPT_IDX

  :ORDER BY 也能使用索引! 这的确是个容易被忽视的知识点。 我们来验证一下:

SQL> select * from emp order by empno;
Execution Plan
----------------------------------------------------------
    0      SELECT STATEMENT Optimizer=CHOOSE
 1    0   TABLE ACCESS (BY INDEX ROWID) OF 'EMP'
 2    1     INDEX (FULL SCAN) OF 'EMPNO' (UNIQUE)

文章地址: http://www.qqread.com/oracle/2008/02/b397131.html 更多文章 更多内容请看系统优化大全Oracle 10g基础应用Oracle 10g优化恢复专题,或进入讨论组讨论。
收藏此文】【 】【打印】【关闭
相关图文阅读
频道图文推荐
健 康 咨 询
时 尚 咨 询
巧巧读书宗旨
相关专题
讨论组问题推荐
站内各频道最新更新文档
站内最新制作专题
热门关键字导读
Photoshop教 程照片处理 照片制作 PS快捷键 抠图
计 算 机 故 障XP系统修复
艺 术 与 设 计设计 流媒体 设计欣赏 边框
计 算 机 安 全ARP
站内频道文章精选
巧巧电脑频道编辑信箱  告诉我们您想看的专题或文章