MySQL面试中如何高效回答索引优化相关问题?

2026-04-29 01:200阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计909个文字,预计阅读时间需要4分钟。

MySQL面试中如何高效回答索引优化相关问题?

不是索引本身变慢,而是MySQL在满足查询时被强迫忽略覆盖索引(Covering Index),转而回表查询。只要SELECT的字段没有全部包含在索引中,比如只有id字段在索引中,也可能会触发回表查询。

  • 复合索引 (a, b, c) 可以高效响应 SELECT a, b FROM t WHERE a = 1 AND b > 10(覆盖索引)
  • SELECT a, b, d FROM t WHERE a = 1 就必须回表取 d,即使 d 是主键——因为 d 不在索引列中
  • SELECT * 几乎必然导致回表,尤其当表有大字段(TEXTBLOB)时,I/O 成倍增加

LIKE '%abc' 为什么用不上索引

前导通配符破坏了 B+ 树的有序查找路径。索引本质是按字典序存储的有序结构,LIKE 'abc%' 可以定位到 abc 开头的范围,但 '%abc' 需要扫描全部叶子节点匹配后缀,等价于全索引扫描。

阅读全文

本文共计909个文字,预计阅读时间需要4分钟。

MySQL面试中如何高效回答索引优化相关问题?

不是索引本身变慢,而是MySQL在满足查询时被强迫忽略覆盖索引(Covering Index),转而回表查询。只要SELECT的字段没有全部包含在索引中,比如只有id字段在索引中,也可能会触发回表查询。

  • 复合索引 (a, b, c) 可以高效响应 SELECT a, b FROM t WHERE a = 1 AND b > 10(覆盖索引)
  • SELECT a, b, d FROM t WHERE a = 1 就必须回表取 d,即使 d 是主键——因为 d 不在索引列中
  • SELECT * 几乎必然导致回表,尤其当表有大字段(TEXTBLOB)时,I/O 成倍增加

LIKE '%abc' 为什么用不上索引

前导通配符破坏了 B+ 树的有序查找路径。索引本质是按字典序存储的有序结构,LIKE 'abc%' 可以定位到 abc 开头的范围,但 '%abc' 需要扫描全部叶子节点匹配后缀,等价于全索引扫描。

阅读全文