SQL|Oracle SQL性能优化最常用的40条建议( 六 )
如果对一个列和一组有限的值进行比较,优化器可能执行多次扫描并对结果进行合并连接。举例:
SELECT * FROM LODGING
WHERE MANAGER IN ('BILL GATES','KEN MULLER')
优化器可能将它转换成以下形式:
SELECT * FROM LODGING
WHERE MANAGER = 'BILL GATES'
OR MANAGER = 'KEN MULLER'
35. CBO下使用更具选择性的索引
- 基于成本的优化器(CBO,Cost-Based Optimizer)对索引的选择性进行判断来决定索引的使用是否能提高效率。
- 如果检索数据量超过30%的表中记录数,使用索引将没有显著的效率提高。
- 在特定情况下,使用索引也许会比全表扫描慢。而通常情况下,使用索引比全表扫描要块几倍乃至几千倍!
- 带有DISTINCT,UNION,MINUS,INTERSECT,ORDER BY的SQL语句会启动SQL引擎执行耗费资源的排序(SORT)功能。DISTINCT需要一次排序操作,而其他的至少需要执行两次排序。
- 通常,带有UNION,MINUS,INTERSECT的SQL语句都可以用其他方式重写。
提高GROUP BY语句的效率,可以通过将不需要的记录在GROUP BY之前过滤掉。
/*低效SQL*/
S
ELECTJOB,AVG(SAL)FROMEMPGROUPBYJOB
HAVINGJOB='PRESIDENT''
OR JOB = 'MANAGER'
/*高效SQL*/
SELECT JOB,AVG(SAL)FROM EMP
WHERE JOB = 'PRESIDENT'
OR JOB = 'MANAGER'
GROUP BY JOB
38. 使用日期
当使用日期时,需要注意如果有超过5位小数加到日期上,这个日期会进到下一天!
SELECT TO_DATE('01-JAN-93'+.99999)
FROM DUAL
结果:
'01-JAN-93 23:59:59'
SELECT TO_DATE('01-JAN-93'+.999999)
FROM DUAL
结果:
'02-JAN-93 00:00:00'
39. 使用显示游标(CURSORS)
使用隐式的游标,将会执行两次操作。第一次检索记录,第二次检查TOO MANY ROWS 这个exception。而显式游标不执行第二次操作。
40. 分离表和索引
- 总是将你的表和索引建立在不同的表空间内(TABLESPACES)。
- 决不要将不属于ORACLE内部系统的对象存放到SYSTEM表空间里。
- 确保数据表空间和索引表空间置于不同的硬盘上。
推荐阅读
- 性能|vivo X50 Pro+拍摄性能评测 镜头算法性能缺一不可
- 打印需求|性能提升 爱普生A3+彩色墨仓式复合机新品上市
- Apple|性能无视对手!苹果A14芯片谍照首曝光:5nm工艺制程加持
- 新浪科技综合@F2.8超广变焦 索尼G大师SEL1224GM性能测评新浪科技综合2020-07-20 06:54:170阅
- 综艺节目|乘风破浪的姐姐们战斗性能力有多强?看逐渐软弱下来的阿kenn导师就知道了
- 方案|性能全面的尼康Z50,什么配件值得买?官方推荐这套配件方案
- AMD|7nm Navi上市一年 AMD点评自家显卡:性能领先N卡20%
- OPPO|鲁大师手机性能排行榜:OPPO Ace2第一,小米10 Pro上榜!
- 高性能|为何异型高性能航母难以诞生?造价太高与失败的代价过于惨重
- 性能|鲁大师发布2020年第二季度显卡性能榜单,前三名均来自英伟达