返回首页

oracle和SQL性能优化(4)

(29) 用WHERE替代ORDER BY:

ORDER BY 子句只在两种严格的条件下使用索引. 

ORDER BY中所有的列必须包含在相同的索引中并保持在索引中的排列顺序. 

ORDER BY中所有的列必须定义为非空. 

WHERE子句使用的索引和ORDER BY子句中所使用的索引不能并列. 

表[url=http://www.bbcweb.cn]DEPT[/url]包含以下列: 

DEPT_CODE PK NOT NULL 

DEPT_DESC NOT NULL 

DEPT_TYPE NULL


低效: (索引不被使用) 

SELECT DEPT_CODE FROM  DEPT  ORDER BY  DEPT_TYPE 

高效: (使用索引) 

SELECT DEPT_CODE  FROM  DEPT  WHERE  DEPT_TYPE > 0


(30) 避免改变索引列的类型.:

当比较不同数据类型的数据时, 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  WHERETO_NUMBER(EMP_TYPE)=123 

因为内部发生的类型转换, 这个索引将不会被用到! 为了避免ORACLE对你的SQL进行隐式的类型转换, 最好把类型转换用显式表现出来. 注意当字符和数值比较时, ORACLE会优先转换数值类型到字符类型


(31) 需要当心的WHERE子句:

某些SELECT 语句中的WHERE子句不使用索引. 这里有一些例子. 

在下面的例子里, (1)‘!=' 将不使用索引. 记住, 索引只能告诉你什么存在于表中, 而不能告诉你什么不存在于表中. (2) ‘||'是字符连接函数. 就象其他函数那样, 停用了索引. (3) ‘+'是数学函数. 就象其他数学函数那样, 停用了索引. (4)相同的索引列不能互相比较,这将会启用全表扫描.


(32) a. 如果检索数据量超过30%的表中记录数.使用索引将没有显著的效率提高. 

b. 在特定情况下, 使用索引也许会比全表扫描慢, 但这是同一个数量级上的区别. 而通常情况下,使用索引比全表扫描要块几倍乃至几千倍!


(33) 避免使用耗费资源的操作:

带有DISTINCT,UNION,MINUS,INTERSECT,ORDER BY的SQL语句会启动SQL引擎执行耗费资源的排序(SORT)功能. DISTINCT需要一次排序操作, 而其他的至少需要执行两次排序. 通常, 带有UNION, MINUS , INTERSECT的SQL语句都可以用其他方式重写. 如果你的数据库的[url=http://www.bbcweb.cn]SORT_AREA_SIZE[/url]调配得好, 使用UNION , MINUS, INTERSECT也是可以考虑的, 毕竟它们的可读性很强


(34) 优化GROUP BY:

提高GROUP BY 语句的效率, 可以通过将不需要的记录在GROUP BY 之前过滤掉.下面两个查询返回相同结果但第二个明显就快了许多.


低效: 

SELECT JOB , AVG(SAL) 

FROM EMP 

GROUP JOB 

HAVING JOB = ‘PRESIDENT' 

OR JOB = ‘MANAGER' 

高效: 

SELECT JOB , AVG(SAL) 

FROM EMP 

WHERE JOB = ‘PRESIDENT' 

OR JOB = ‘MANAGER' 

GROUP JOB


最新发布
asp生成静态网页
Socket相关知识
网页制作中XML与HTML的区别
怎么查看汽车行驶轨迹
layer.open打开iframe页面,更新父级页面的元素值
百度知道,不能滥用导流量
保存到数据库前替换空格/回车
SQLServer 2014已成功与服务器建立连接,但是在登录前的握手期间发生错误。 (provider: SSL Provider, error: 0 - 等待的操作过时。
网站空间 服务器与网站优化排名关系
Access数据库相关知识
热门阅读
单位车辆管理系统解决方案
工厂生产订单管理系统
供应链(报单)订单管理系统V1上线
linux yum安装php7.4
企业网站的首页标题怎么设置有利于排名优化
同个页面有多个分页模块处理之我见
企业网站推广
车辆派车小程序基础版发布
Css:制作一个更漂亮一些的多选列表框
JS实现的网页无提示自动关闭

微信扫以下二维码添加好友咨询