SQL|Oracle SQL性能优化最常用的40条建议( 二 )
- 删除表中记录的时候,如果不需要恢复的情况之下应该尽量使用Truncate而不是Delete。
- Truncate仅适用于删除全表的记录。
只要有可能,在程序中尽量多使用COMMIT, 这样程序的性能得到提高,需求也会因为COMMIT所释放的资源而减少。
COMMIT所释放的资源:
- 回滚段上用于恢复数据的信息。
- 被程序语句获得的锁。
- redo log buffer 中的空间。
- ORACLE为管理上述3种资源中的内部花费。
Select count(*) from tablename; Select count(1) from tablename; Select count(column) from tablename;一般认为,在没有主键索引的情况之下,第二种COUNT(1)方式最快。如果只有一列且无索引COUNT(*)反而比较快, 如果有索引列,当然是使用索引列COUNT(column)最快。
13. 用Where子句替换Having子句
避免使用HAVING子句,HAVING 只会在检索出所有记录之后才对结果集进行过滤。这个处理需要排序、总计等操作。如果能通过WHERE子句限制记录的数目,就能减少这方面的开销。
14. 减少对表的查询操作
在含有子查询的SQL语句中,要注意减少对表的查询操作。
/*低效SQL*/SELECT TAB_NAME FROM TABLESWHERE TAB_NAME =(SELECT TAB_NAME FROM TAB_COLUMNSWHERE VERSION = 604)AND DB_VER =(SELECT DB_VER FROM TAB_COLUMNSWHERE VERSION = 604)/*高效SQL*/SELECT TAB_NAME FROM TABLESWHERE (TAB_NAME,DB_VER)=(SELECT TAB_NAME,DB_VERFROM TAB_COLUMNSWHERE VERSION = 604)15. 使用表的别名(Alias)
当在SQL语句中连接多个表时, 请使用表的别名并把别名前缀于每个Column上.这样一来,就可以减少解析的时间并减少那些由Column歧义引起的语法错误。
Column歧义指的是由于SQL中不同的表具有相同的Column名,当SQL语句中出现这个Column时,SQL解析器无法判断这个Column的归属。
16. 用EXISTS替代IN
在许多基于基础表的查询中,为了满足一个条件 ,往往需要对另一个表进行联接。在这种情况下,使用EXISTS(或NOT EXISTS)通常将提高查询的效率。
/*低效SQL*/SELECT * FROM EMP WHERE EMPNO > 0AND DEPTNO IN (SELECT DEPTNO FROM DEPT WHERE LOC = 'MELB')/*高效SQL*/SELECT * FROM EMPWHERE EMPNO > 0AND EXISTS (SELECT1FROM DEPT WHERE DEPT.DEPTNO = EMP.DEPTNOAND LOC = 'MELB')17. 用NOT EXISTS替代NOT IN
在子查询中,NOT IN子句将执行一个内部的排序和合并,对子查询中的表执行一个全表遍历,因此是非常低效的。为了避免使用NOT IN,可以把它改写成外连接(Outer Joins)或者NOT EXISTS。
/*低效SQL*/SELECT * FROM EMP WHERE DEPT_NO NOT IN (SELECT DEPT_NO FROM DEPT WHERE DEPT_CAT='A')/*高效SQL*/SELECT * FROM EMP EWHERE NOT EXISTS (SELECT 1FROM DEPT DWHERE D.DEPT_NO = E.DEPT_NOAND DEPT_CAT ='A')18. 用表连接替换EXISTS
通常来说 ,采用表连接的方式比EXISTS更有效率 。
/*低效SQL*/SELECT ENAMEFROM EMP EWHERE EXISTS (SELECT 1FROM DEPTWHERE DEPT_NO = E.DEPT_NOAND DEPT_CAT = 'A')/*高效SQL*/SELECT ENAMEFROM DEPT D,EMP EWHERE E.DEPT_NO = D.DEPT_NOAND D.DEPT_CAT = 'A'19. 用EXISTS替换DISTINCT
当提交一个包含对多表信息(比如部门表和雇员表)的查询时,避免在SELECT子句中使用DISTINCT。一般可以考虑用EXIST替换。EXISTS 使查询更为迅速,因为RDBMS核心模块将在子查询的条件一旦满足后,立刻返回结果。
/*低效SQL*/SELECT DISTINCT D.DEPT_NO,D.DEPT_NAME
推荐阅读
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 性能|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年第二季度显卡性能榜单,前三名均来自英伟达
