MySQL面试题——联合索引

总结于JavaGuide

知识点总结

请解释一下 MySQL 的联合索引及其最左前缀原则

如果有索引 联合索引(a,b,c),查询 a=1 AND c=1 会走索引么?c=1 呢?b=1 AND c=1 呢? b = 1 AND a = 1 AND c = 1 呢?

回答

一、联合索引 & 最左前缀原则解释

  1. 联合索引(复合索引):基于多个字段组合创建 的索引,比如(a,b,c),索引数据会按「a 字段排序 → 同 a 值按 b 排序 → 同 b 值按 c 排序」的规则存储。
  2. 最左前缀原则:MySQL 联合索引的核心匹配规则,必须从索引的最左侧第一个字段开始匹配,才能触发索引;跳过左侧字段、直接匹配右侧字段,索引会完全失效;中间字段缺失时,仅能匹配左侧连续字段的部分索引,右侧字段无法利用索引。

二、基于联合索引(a,b,c)的 4 个查询场景逐一回答

✅ 1. a=1 AND c=1会走索引(仅 a 字段的部分索引),c 字段无法利用索引;原因:匹配了最左的 a 字段,满足前缀要求,但跳过中间 b 字段,右侧 c 失效。

❌ 2. c=1完全不走索引;原因:未匹配最左的 a 字段,直接查最右侧字段,违背最左前缀原则,触发全表扫描。

❌ 3. b=1 AND c=1完全不走索引;原因:未匹配最左的 a 字段,直接查 b、c,无任何前缀匹配,索引失效

。✅ 4. b=1 AND a=1 AND c=1走完整的联合索引(全索引命中) ;原因:MySQL 查询优化器会自动调整 AND 等值条件的顺序,最终等效 a=1 AND b=1 AND c=1,完整匹配索引所有字段。

相关推荐
数据知道8 分钟前
PostgreSQL 核心原理:系统内部的对象寻址机制(OID 对象标识符)
数据库·postgresql
2501_9011478324 分钟前
面试必看:优势洗牌
笔记·学习·算法·面试·职场和发展
李日灐25 分钟前
C++进阶必备:红黑树从 0 到 1: 手撕底层,带你搞懂平衡二叉树的平衡逻辑与黑高检验
开发语言·数据结构·c++·后端·面试·红黑树·自平衡二叉搜索树
倔强的石头_38 分钟前
关系数据库替换用金仓:数据迁移过程中的完整性与一致性风险
数据库
Elastic 中国社区官方博客1 小时前
使用 Groq 与 Elasticsearch 进行智能查询
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
穿过锁扣的风1 小时前
一文搞懂 SQL 五大分类:DQL/DML/DDL/DCL/TCL
数据库·microsoft·oracle
l1t1 小时前
DeepSeek总结的SNKV — 无查询处理器的 SQLite 键值存储
数据库·sqlite·kvstore
洛豳枭薰1 小时前
MySQL 梳理
数据库·mysql
Bella的成长园地1 小时前
为什么c++中的条件变量的 wait() 函数需要配合while 循环或谓词?
c++·面试
九.九1 小时前
CANN 算子生态的底层安全与驱动依赖:固件校验与算子安全边界的强化
大数据·数据库·安全