• mysql执行慢的排查手册 season


    最近遇到了mysql查询慢的问题,然后吧废了顿周折,现在把遇到的问题记录下来,排查的时候,需要按照这个顺序排查

    1. 如果有表关联,多表查询,记得将关联字段都添加索引(阿里巴巴代码规范里提到过)
    2. 模糊搜索导致的索引失效,WHERE name LIKE '%冰',模糊搜索前缀/左侧进行模糊搜索,索引失效
    3. 避免在索引字段上添加函数,会导致索引失效,最常见的例子是,date_format(beginDate, '%Y-%m-%d') <= date_format(now(), '%Y-%m-%d'),数据库比较的就是字符串,所以这里也没必要这么写,影响效率得不偿失
    4. 如果是生产环境,需要检测下mysql缓存池的配置,是否进行过配置
    5. 如果是inner join,使用straight_join,查看真实执行的顺序,改变下表关联的顺序,查看效率问题,最好小表驱动大表
    6. 在多表查询过程中,同上,表连接顺序影响很大,需要保证从左往右,尽可能地保证每一个表都能限制最大的范围。比如说,AB表关联,查询条件A.a能将范围缩小到10%数据,B.b能将范围缩小到1%的数据,那么B straight_join A,很可能效率更高
    7. 时间范围判断时,尝试在时间字段上添加索引

    解释:
    哎呀,待补上

    梦想不多,口袋有糖,卡里有钱,未来有你
  • 相关阅读:
    Java设计模式--命令模式
    linux 挂载windows盘
    C# 对含有向量偏移的明文进行AES加解密
    Vue修仙之旅之Vue初尝
    Cookie的Secure属性
    Webserver信息泄露的解决方案--使用StripHeaders模块删除不必要的header
    window自定义事件
    vue typescript .eslintrc.js
    css word-break: break-word;无效
    vscode vue 片段
  • 原文地址:https://www.cnblogs.com/season-qd/p/15645523.html
Copyright © 2020-2023  润新知