MySQL的ABC联合索引

建立了ABC联合索引

sql 复制代码
INDEX idx_abc (A, B, C)

各种查询条件是否会走ABC联合索引,核心在于查询条件是否满足最左前缀匹配原则(查询条件必须从索引最左列开始连续匹配

查询条件简写 是否可能走 idx_abc 实际利用程度 说明(是否满足最左前缀)
A 用到 A 满足
B 不会 不用 不满足,缺少最左列 A
AB 用到 A、B 满足,连续命中前两列
AC 用到A, MySQL 5.6 以前 C 不能用于连续定位,5.6+ 可能通过 ICP 在索引层过滤 不满足,因为跳过了 B,所以不能完整利用 (A,B,C); 5.6 前通常在 Server 层判断 C, 5.6+ 可能在存储引擎层先判断 C,从而减少回表;是否回表取决于是否覆盖索引
BC 不会 不用 不满足,缺少最左列 A
ABC 用到 A、B、C 满足,完整命中
CBA 用到 A、B、C 满足,优化器会重排为ABC,ABC满足
A或B 不一定 用到 A,会用B 用不到A,则后面也不用 比较复杂,OR 逻辑要拆成两个分支看: A=? 分支满足最左前缀, B=? 分支不满足最左前缀;因此整体是否走联合索引不稳定
A或A 用到 A 满足,类似 A IN (...)
A IN + B 用到 A、B 满足,IN 可视为多个等值匹配
A IN + B IN + C 一般可用 A、B、C 满足,都是等值匹配,较友好
A范围 用到 A 范围 满足,从 A 开始做范围扫描
A范围 + B 主要用 A 满足,A 已经是范围,B 通常不能继续精确定位
A + B范围 用到 A、B 满足,B 作为范围条件
A + B范围 + C 用到 A、B,C 多数过滤 满足,B 范围之后,C 通常不能继续定位
A前缀LIKE 用到 A 范围 满足,如 A LIKE 'abc%'
A后缀LIKE 不会 不用 不满足,如 A LIKE '%abc'

上面查询语法的完全写法

简写 示例语法
ABC WHERE A = ? AND B = ? AND C = ?
A或B WHERE A = ? OR B = ?
A IN + B IN + C WHERE A IN (?, ?) AND B IN (?, ?) AND C = ?
A + B范围 + C WHERE A = ? AND B > ? AND C = ?
A前缀LIKE WHERE A LIKE 'abc%'
相关推荐
wear工程师2 小时前
可重复读能不能防幻读?MVCC 和 Next-Key Lock 到底谁在起作用
mysql·面试
AOwhisky2 小时前
Kubernetes(K8s)学习笔记(第十四期):集群存储与有状态应用(下篇):StatefulSet 有状态应用管理
redis·笔记·mysql·云原生·kubernetes·云计算·k8s
EntyIU2 小时前
CentOS-高可用部署手册-MySQL双主RedisNginx
linux·mysql·centos
承渊政道3 小时前
【MySQL数据库学习】(MySQL访问、连接池原理与简易网站数据流动)
数据库·学习·mysql·mysql访问·连接池原理
wefg15 小时前
【MySQL】索引(索引底层原理/创建/查看/删除主键、普通、联合、前缀、全文索引)
数据库·mysql
周杰伦的稻香12 小时前
MySQL8.0+中引入的SET_USER_ID权限迭代SUPER权限指定 DEFINER
数据库·mysql
韩楚风14 小时前
【参天引擎】Cantian 服务端框架全景解析:进程架构、模块组成与交互关系
数据库·mysql·架构·cantian
vigor51216 小时前
MySQL通过Mango实现分库分表
android·数据库·mysql
KASH_SHADOW18 小时前
8-Mysql的安装与配置
数据库·mysql·adb