当前位置: 首页 > news >正文

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. 深度分页查询

相关文章:

  • H5小游戏如何提升APP变现收益?
  • SQL执行时间过长如何优化
  • 阿里云国外服务器多少钱一个月?24元/月
  • VRPSolverEasy:支持VRP问题快速建模的精确算法Python包
  • 架构篇05-复杂度来源:高可用
  • go语言(一)----声明变量
  • 【JavaEE】网络原理:网络中的一些基本概念
  • 制作一个Python聊天机器人
  • Git一台电脑 配置多个账号
  • PXE高效批量网络装机
  • 矩阵和矩阵如何相乘?
  • openssl3.2 - 官方demo学习 - test - certs
  • 【计算机网络】TCP握手与挥手:三步奏和四步曲
  • 低代码+物联网: 重塑智慧社区,开启未来生活新纪元
  • 市场复盘总结 20240119
  • 从数据角度分析年龄与NBA球员赛场表现的关系【数据分析项目分享】
  • 【RT-DETR有效改进】华为 | Ghostnetv1一种专为移动端设计的特征提取网络
  • 基于SpringBoot Vue家政服务预约平台系统
  • 【C++算法】构建最优哈夫曼树
  • easy Exsel导出
  • 陕西河南山西等地将现“干热风”灾害,小麦产区如何防范?
  • 中巴续签双边本币互换协议,进一步深化金融战略合作
  • 硅料收储挺价“小作文”发酵光伏板块罕见大涨,知情人士:确实在谈
  • 中美日内瓦经贸会谈联合声明
  • 同济大学原常务副校长、著名隧道及地下工程专家李永盛逝世
  • 傅利叶提出下个十年战略,CEO顾捷:机器人要有温度,要用实际价值来定义形态