-
-
- 慢查询出现的情况:
-
-
SQL执行慢如何解决?
可以采用MySQL自带的分析工具Explain。
-
-
- 通过key和key_len检查是否命中了索引(如果你已经添加了索引,还可以判断索引是否失效)
- 通过type字段查看SQL是否有进一步优化的空间,是否存在全索引扫描或全盘扫描的情况
- 通过Extra建议,判断是否出现了回表的情况,如果出现了,可以尝试添加索引或修改返回字段来修复。
-
-
通过key和key_len他们两个查看是否可能会命中索引。
type类型:
-
- NULL:没有查询到表。不常见
- system:查询的是系统中的表 。不常见
- const:根据主键查询。常见
- eq_ref:主键索引查询或唯一索引查询
- ref:索引查询 (他有可能查询到多条数据。和eq_ref是不同的)
- range:范围查询
- index:索引树扫描(遍历整个索引树进行扫描)
- all:全盘扫描
-
可以采用explain或者DESC命令获取MySQL如何执行select语句的信息。
直接在select语句前加上explain或者DESC。
执行计划查询结果中:

-
- possible_key 当前SQL可能会使用到的索引
- key当前SQL实际命中的索引
- key_len索引占用的大小。
- Extra额外的优化建议。
-
聚合查询、多表查询、表数据量过大查询**(这三个可以通过SQL执行计划找到原因)**
-
-
- 聚合查询 (新增一个临时表来解决)
- 多表查询 (试着优化SQL语句的结构)
- 表数据量过大查询 (通过添加索引来解决)
- 深度分页查询
-
-
-
SQL慢语句执行的很慢,如何分析优化呢,(如何优化的呢?)
java牛虻2024-01-22 17:06
相关推荐
知识分享小能手5 分钟前
Oracle 19c入门学习教程,从入门到精通, Oracle 表空间与数据文件管理详解(9)zhengfei61135 分钟前
Chroma DB — 未经授权的信息披露KaiwuDB1 小时前
KaiwuDB 获评“2025 中国大数据产业年度国产化优秀代表厂商”百***07451 小时前
一步API+Gemini 3.0 Pro进阶实战:多模态开发、性能调优与项目落地不想写bug呀1 小时前
Redis主从复制介绍颜颜yan_1 小时前
Oracle 迁移到 KingbaseES 实战:从评估到追平的一套可落地流程砚边数影2 小时前
Oracle迁移替换实战:金仓数据库如何破解企业数据迁移难题burning_maple2 小时前
mysql数据库笔记Navicat中国2 小时前
1月31日·上海 | Navicat 鼎力助阵 OceanBase 年度嘉年华Pocker_Spades_A3 小时前
Oracle向KingbaseES迁移:核心痛点拆解与根源分析