滴滴二面:MySQL执行计划中,Key有值,还是很慢怎么办?

文章内容收录到个人网站,方便阅读hardyfish.top/

如果 执行计划中 key 有值,type=index,但查询仍然很慢

说明索引并没有按照预期优化查询性能,而是发生了全索引扫描(Index Full Scan)。

这种情况的核心问题可能出在索引使用方式或查询优化上。

如何正确分析 SQL 执行计划?

EXPLAIN 结果中,几个重要的字段:

字段 含义 重点
id 查询执行的步骤 越大表示执行顺序越靠后
type 访问类型 影响查询效率的关键
possible_keys 可能使用的索引 可供查询选择的索引
key 实际使用的索引 如果是 NULL,说明没用索引
rows 预计扫描行数 值越大说明查询性能越差
Extra 额外信息 是否 Using indexUsing where; Using index

问题分析:type=index 代表什么?

如果 type=index,说明进行了全索引扫描(Index Full Scan),即遍历整个索引树,而不是通过索引加速查询。

这个情况类似于 全表扫描(type=ALL),只是扫描的是索引而非数据表。

示例:

sql 复制代码
EXPLAIN SELECT col1 FROM my_table WHERE col2 = 'xxx';

可能返回:

asciidoc 复制代码
+----+-------+---------------+----------+--------------------------+
| id | type  | possible_keys | key      | Extra                    |
+----+-------+---------------+----------+--------------------------+
|  1 | index | NULL          | idx_col2 | Using where; Using index |
+----+-------+---------------+----------+--------------------------+

Extra 中 出现 Using where; Using index,意味着:

SQL 确实用了索引 idx_col2(key 列)。

但查询仍然需要回表或扫描整个索引树

可能的原因:索引未能高效筛选数据

可能导致查询慢的原因

  1. 索引失效:没有满足最左前缀匹配

    • 复合索引 (a, b, c),如果 WHEREb, c,则索引失效。
    • 建议:调整查询,确保 WHERE 子句符合索引最左匹配原则
  2. 索引筛选性差,导致大量数据扫描

    • 低选择性索引(如 status=1 这种大量重复值)会导致扫描大量行
    • 优化:换更高区分度的列建立索引
  3. 回表查询导致性能下降

    • EXTRA中如果出现Using where; Using index,意味着:

      • 查询需要回表(即索引不覆盖查询列)
    • 优化方案:创建覆盖索引,减少回表操作

      sql 复制代码
      -- 假设查询 `SELECT col1 FROM my_table WHERE col2 = 'xxx'`
      -- 现有索引 idx_col2(col2)
      -- 改进:创建联合索引 (col2, col1) 避免回表
      CREATE INDEX idx_col2_col1 ON my_table (col2, col1);
  4. 使用 LIKE '%xx' 或者 函数操作列,导致索引失效

    • WHERE UPPER(name) = 'JOHN' 使得 name 索引失效
    • 解决方案:避免对索引列使用函数,或者考虑创建函数索引

解决方案

问题 解决方案
索引未匹配 WHERE 调整 SQL 确保最左匹配
索引选择性差 选择更具区分度的索引
需要回表查询 覆盖索引优化
LIKE '%xx' 导致全索引扫描 改进索引或考虑全文索引(FULLTEXT

总结

key 有值但查询仍然很慢:

重点关注 typeExtra 字段,看是否 Using where; Using index

可能是全索引扫描type=index)导致的,意味着索引没加速查询

检查索引是否最左匹配、是否需要回表、索引选择性是否合理

尝试优化 SQL 结构 ,或创建覆盖索引,减少回表扫描

相关推荐
培风图南以星河揽胜4 分钟前
Java实习模拟面试|离散数学|概率论|金融英语|数据库实战|职业规划|期末冲刺|今日本科计科要闻速递:技术分享与学习指南
java·面试·概率论
能鈺CMS5 分钟前
能鈺CMS · 虚拟发货源码
java·大数据·数据库
sheji34168 分钟前
【开题答辩全过程】以 环保监督管理系统为例,包含答辩的问题和答案
java·eclipse
不会玩电脑的Xin.11 分钟前
Web请求乱码解决方案
java·javaweb
Billow_lamb19 分钟前
Spring Boot2.x.x 全局错误处理
java·spring boot·后端
苏三的开发日记20 分钟前
Java后台定时器导致系统奔溃的原因分析
后端
remaindertime22 分钟前
基于Ollama和Spring AI:实现本地大模型对话与 RAG 功能
人工智能·后端·ai编程
Lear22 分钟前
Spring Boot异步任务实战:优化耗时操作,提升系统性能
后端
编程火箭车23 分钟前
【Java SE 基础学习打卡】14 Java 注释
java·编程规范·代码注释·api文档·代码可读性·javadoc·文档注释
雁于飞31 分钟前
分布式基础
java·spring boot·分布式·spring·wpf·cloud native