SQL慢语句执行的很慢,如何分析优化呢,(如何优化的呢?)

      1. 慢查询出现的情况:
      1. SQL执行慢如何解决?

        可以采用MySQL自带的分析工具Explain。

          1. 通过key和key_len检查是否命中了索引(如果你已经添加了索引,还可以判断索引是否失效)
          2. 通过type字段查看SQL是否有进一步优化的空间,是否存在全索引扫描或全盘扫描的情况
          3. 通过Extra建议,判断是否出现了回表的情况,如果出现了,可以尝试添加索引或修改返回字段来修复。
      2. 通过key和key_len他们两个查看是否可能会命中索引。

        type类型:

        1. NULL:没有查询到表。不常见
        2. system:查询的是系统中的表 。不常见
        3. const:根据主键查询。常见
        4. eq_ref:主键索引查询或唯一索引查询
        5. ref:索引查询 (他有可能查询到多条数据。和eq_ref是不同的)
        6. range:范围查询
        7. index:索引树扫描(遍历整个索引树进行扫描)
        8. all:全盘扫描
      3. 可以采用explain或者DESC命令获取MySQL如何执行select语句的信息。

        直接在select语句前加上explain或者DESC。

        执行计划查询结果中:

        1. possible_key 当前SQL可能会使用到的索引
        2. key当前SQL实际命中的索引
        3. key_len索引占用的大小。
        4. Extra额外的优化建议。
      4. 聚合查询、多表查询、表数据量过大查询**(这三个可以通过SQL执行计划找到原因)**

          1. 聚合查询 (新增一个临时表来解决)
          2. 多表查询 (试着优化SQL语句的结构)
          3. 表数据量过大查询 (通过添加索引来解决)
          4. 深度分页查询
相关推荐
TDengine (老段)1 小时前
连接 TDengine 遇到报错 “failed to connect to server, reason: Connection refused” 怎么办?
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
李慕婉学姐2 小时前
Springboot黄河文化科普网站5q37v(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
Cabbage_acmer2 小时前
MySQL期中考试突击!
数据库·mysql
Lu Yao_2 小时前
Redis 缓存
数据库·redis·缓存
小桥流水人家哇3 小时前
性能测试单场景测试时,是设置并发读多个文件,还是设置不同的用户读不同的文件?
数据库·性能测试技巧
表示这么伤脑筋的题我不会3 小时前
Oracle 21C 部署ogg踩过的坑
数据库·oracle
你不是我我3 小时前
【Java 开发日记】MySQL 与 Redis 如何保证双写一致性?
数据库·redis·缓存
望获linux3 小时前
【实时Linux实战系列】实时 Linux 在边缘计算网关中的应用
java·linux·服务器·前端·数据库·操作系统
fredinators3 小时前
数据库专家
大数据·数据库
fredinators4 小时前
数据库flask访问
数据库·oracle·flask