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

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

来源:qqread 作者:佚名 出处:巧巧读书 2008-02-19 进入讨论组
上一页 1 2 3 

    3. 避免改变索引列的类型

  当比较不同数据类型的数据时, ORACLE自动对列进行简单的类型转换。

  假设 EMPNO是一个数值类型的索引列。

  SELECT …
  FROM EMP
  WHERE EMPNO = ‘123’

  实际上,经过ORACLE类型转换, 语句转化为:

  SELECT …
  FROM EMP
  WHERE EMPNO = TO_NUMBER(‘123’)

  幸运的是,类型转换没有发生在索引列上,索引的用途没有被改变。

  现在,假设EMP_TYPE是一个字符类型的索引列。

  SELECT …
  FROM EMP
  WHERE EMP_TYPE = 123

  这个语句被ORACLE转换为:

  SELECT …
  FROM EMP
  WHERE TO_NUMBER(EMP_TYPE)=123

  因为内部发生的类型转换, 这个索引将不会被用到!

  :为了避免ORACLE对你的SQL进行隐式的类型转换, 最好把类型转换用显式表现出来。 注意当字符和数值比较时, ORACLE会优先转换数值类型到字符类型。

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