• ORACLE 数据库优化原则


    ORACLE 数据库优化原则

    一、SQL语句用大写的;

    因为Oracle总是先解析SQL语句,把小写的字母转换成大写的再厉行。

    二、避免在索引列上利用NOT等闲

    我们要避免在索引列上利用NOT, NOT会发生在和在索引列上利用函数雷同的波及。“碰到”NOT,他就会停止利用索引转而厉行全表扫描。

    三、用Where子句替换HAVING子句

    避免使用HAVING子句, HAVING 只会在检索出所有记录之后才对结果集进行过滤.
    这个处理需要排序,总计等操作如果能通过WHERE子句限制记录的数目,那就能减少这方面的开销.

    例如:

    低效:
    SELECT REGIONAVG(LOG_SIZE)
    FROM LOCATION
    GROUP BY REGION
    HAVING REGION REGION != SYDNEY
    AND REGION != PERTH

    高效
    SELECT REGIONAVG(LOG_SIZE)
    FROM LOCATION
    WHERE REGION REGION != SYDNEY
    AND REGION != PERTH
    GROUP BY REGION
    (译者按: HAVING 中的条件一般用于对一些集合函数的比较,COUNT() 等等.
    除此而外,一般的条件应该写在WHERE子句中)

    四、尽量少用子查询 合并可以合并的子查询

    例如:
    低效
    SELECT TAB_NAME
    FROM TABLES
    WHERE TAB_NAME = ( SELECT TAB_NAME
    FROM TAB_COLUMNS
    WHERE VERSION = 604)
    AND DB_VER= ( SELECT DB_VER
    FROM TAB_COLUMNS
    WHERE VERSION = 604)

    高效
    SELECT TAB_NAME
    FROM TABLES
    WHERE (TAB_NAME,DB_VER)
    = ( SELECT TAB_NAME,DB_VER)
    FROM TAB_COLUMNS
    WHERE VERSION = 604)

     

    五、不要用*

    例如: select  count(*) from table  select *from table

    六、根据oracle的SQL语句解析器进行优化

       首先解释一下oracle 解释SQL的语句的顺序,oracle在解释SQL语句的时候是按照从右到左
    的顺序进行解析。所以要把检索效率最高的表,记录最少的表写在FROM的最右表也就是基础
    表的选择.

    七、使用表的别名(Alias):

    当在SQL语句中连接多个表时请使用表的别名并把别名前缀于每个Column.这样一来,就可以减少解析的时间并减少那些由Column歧义引起的语法错误

    八、用EXISTS替代IN、用NOT EXISTS替代NOT IN:

    在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接.在这种情况下使用EXISTS(NOT EXISTS)通常将提高查询的效率在子查询中,NOT IN子句将执行一个内部的排序和合并无论在哪种情况下,NOT IN都是最低效的 (因为它对子查询中的表执行了一个全表遍历). 为了避免使用NOT IN ,我们可以把它改写成外连接(Outer Joins)NOT EXISTS.
    例子:
    (高效)SELECT * FROM  EMP (基础表)  WHERE  EMPNO > 0  AND  EXISTS (SELECT 1  FROM DEPT  WHERE  DEPT.DEPTNO = EMP.DEPTNO  AND  LOC = MELB')
    (低效)SELECT * FROM  EMP (基础表)  WHERE  EMPNO > 0  AND  DEPT NOT IN(SELECT DEPTNO  FROM  DEPT  WHERE  LOC = MELB')

    九、避免在索引列上使用计算.

    WHERE子句中,如果索引列是函数的一部分.优化器将不使用索引而使用全表扫描. 
    举例: SAL为索引列
    低效: 
    SELECT … FROM  DEPT  WHERE SAL * 12 > 25000; 
    高效
    SELECT … FROM DEPT WHERE SAL > 25000/12;

    十、用>=替代>;

    高效
    SELECT * FROM  EMP  WHERE  DEPTNO >=4 
    低效
    SELECT * FROM EMP WHERE DEPTNO >3 
    两者的区别在于前者DBMS将直接跳到第一个DEPT等于4的记录而后者将首先定位到DEPTNO=3的记录并且向前扫描到第一个DEPT大于3的记录.

    十一、用IN来替换OR 

    这是一条简单易记的规则,但是实际的执行效果还须检验,在ORACLE8i下,两者的执行路径似乎是相同的. 
    低效
    SELECT. FROM LOCATION WHERE LOC_ID = 10 OR LOC_ID = 20 OR LOC_ID = 30 
    高效 
    SELECT… FROM LOCATION WHERE LOC_IN  IN (10,20,30);

    十二、避免在索引列上使用IS NULL和IS NOT NULL

    避免在索引中使用任何可以为空的列,ORACLE将无法使用该索引.对于单列索引,如果列包含空值,索引中将不存在此记录对于复合索引,如果每个列都为空,索引中同样不存在此记录. 如果至少有一个列不为空,则记录存在于索引中.举例如果唯一性索引建立在表的A列和B列上并且表中存在一条记录的A,B值为(123,null) , ORACLE将不接受下一条具有相同A,B值(123,null)的记录(插入). 然而如果所有的索引列都为空,ORACLE将认为整个键值为空而空不等于空因此你可以插入1000 条具有相同键值的记录,当然它们都是空因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引.
    低效: (索引失效
    SELECT … FROM  DEPARTMENT  WHERE  DEPT_CODE IS NOT NULL; 
    高效: (索引有效
    SELECT … FROM  DEPARTMENT  WHERE  DEPT_CODE >=0;

    十三、需要当心的WHERE子句

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

    十四、优化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

    十五、用EXISTS替换DISTINCT:

    当提交一个包含一对多表信息(比如部门表和雇员表)的查询时,避免在SELECT子句中使用DISTINCT. 一般可以考虑用EXIST替换, EXISTS 使查询更为迅速,因为RDBMS核心模块将在子查询的条件一旦满足后,立刻返回结果例子:
    (低效): 
    SELECT  DISTINCT  DEPT_NO,DEPT_NAME  FROM  DEPT D , EMP E 
    WHERE  D.DEPT_NO = E.DEPT_NO 
    (高效): 
    SELECT  DEPT_NO,DEPT_NAME  FROM  DEPT D  WHERE  EXISTS ( SELECT X' 
    FROM  EMP E  WHERE E.DEPT_NO = D.DEPT_NO);

     

  • 相关阅读:
    Storm的并行度、Grouping策略以及消息可靠处理机制简介
    storm入门原理介绍
    Kafka学习笔记-Java简单操作
    批量复制word文档,并生成以日期为后缀名的批量文档攻略,批量生成word文档
    数组
    分支结构,循环结构学习整理
    java中的运算符
    Java中的变量和基本数据类型知识
    Java开发环境描述
    使用Map,统计字符串中每个字符出现的次数
  • 原文地址:https://www.cnblogs.com/yuanermen/p/3334261.html
Copyright © 2020-2023  润新知