• 提高SQL执行效率的16种方法


     
    项目中优化sql语句执行效率的方法:
    1)尽量选择较小的列
    2)将where中用的比较频繁的字段建立索引
    3)select子句中避免使用‘*’
    4)避免在索引列上使用计算、not in 和<>等操作
    5)当只需要一行数据的时候使用limit 1
    6)保证单表数据不超过200W,适时分割表。
    针对查询较慢的语句,可以使用explain 来分析该语句具体的执行情况。

    ------------------------------------------------------------------------------

    1.尽量不要在where中包含子查询;

    关于时间的查询,尽量不要写成:where to_char(dif_date,’yyyy-mm-dd’)=to_char(’2007-07-01′,’yyyy-mm-dd’);

    2.在过滤条件中,可以过滤掉最大数量记录的条件必须放在where子句的末尾;

    FROM 子句中写在最后的表(基础表,driving table)将被最先处理,在FROM子句中包含多个表的情况下,你必须选择记录条数最少的表作为基础表。如果有三个以上的连接查询,那就需要选择交叉表 (intersection table)作为基础表,交叉表是指那个被其他表所引用的表;

    3.采用绑定变量

    4.在WHERE中尽量不要使用OR

    5.用EXISTS替代IN、用NOT EXISTS替代NOT IN;

    6.避免在索引列上使用计算:WHERE SAL*12>25000;

    7.用IN来替代OR: WHERE LOC_ID=10 OR LOC_ID=15 OR LOC_ID=20

    8.避免在索引列上使用IS NULL和IS NOT NULL;

    9.总是使用索引的第一个列;

    10.用UNION-ALL替代UNION;

    11.避免改变索引列的类型:SELECT…FROM EMP WHERE EMPNO=’123′,由于隐式数据类型转换,to_char(EMPNO)=’123′,因此,将不采用索引,一般在采用字符串拼凑动态SQL语句出现;

    12.’!=’ 将不使用索引;

    13.优化GROUP BY;

    14.避免带有LIKE参数的通配符,LIKE ’4YE%’使用索引,但LIKE ‘%YE’不使用索引

    15. 避免使用困难的正规表达式,例如select * from customer where zipcode like “98___”,即便在zipcode上建立了索引,在这种情况下也还是采用顺序扫描的方式。如果把语句改成select * from customer where zipcode>”98000″,在执行查询时就会利用索引来查询,显然会大大提高速度;

    16.尽量明确的完成SQL语句,尽量少让数据库工作。比如写SELECT语句时,需要把查询的字段明确指出表名。尽量不要使用SELECT *语句。组织SQL语句的时候,尽量按照数据库的习惯进行组织。

    在CSDN逛时看到的一个资源,先记下,有些还要亲自再去试一遍,看执行计划是否真的优化。

  • 相关阅读:
    硬盘
    vim 使用技巧
    R语言自定义函数中的位置参数、关键字参数、默认参数
    R语言中批量加载函数
    R语言中如何在函数内部定义全局变量
    centos7.9中安装dnf;bash: dnf: command not found...
    ubantu中实现root用户登录ssh
    linux系统中如何修改主机名
    Ubuntu 20.04.2如何root登录
    清北学堂模拟day6 兔子
  • 原文地址:https://www.cnblogs.com/xuyatao/p/6738779.html
Copyright © 2020-2023  润新知