说说复合索引之最左前缀原理?

分析&回答

MySQL中的索引可以以一定顺序引用多个列,这种索引叫做复合(联合)索引。

如果表 Ta 中存在索引 A、B、(C、D)

规则1:全列匹配

复制代码
SELECT * FROM Ta  WHERE E = 'F1' AND A ='10001';
复制代码

若没有按照索引顺序时,mysql查询优化器会自动的调整顺序来使用定义好的索引,如果我们将where中的条件顺序颠倒效果是一样的。

规则2:最左前缀匹配

复制代码
SELECT * FROM Ta  WHERE  A ='10001' AND B = 'B001' ;
复制代码

当查询条件精确匹配索引的左边连续一个或几个列时,只用到了索引的第一列前缀

规则3:查询条件没有指定索引第一列

复制代码
SELECT * FROM Ta  WHERE  D = 'D001' ;
复制代码

由于不是最左前缀,索引这样的查询显然用不到索引。

规则4:匹配某列的前缀字符串。

复制代码
SELECT * FROM Ta  WHERE  C LINK 'C001%' ;
复制代码

此时可以用到索引,如果通配符%不出现在开头,则可以用到索引。

规则5:范围查询(范围查询后面的列将无法使用索引)

对于范围条件查询,MYSQL无法再使用范围后面的其他索引列了。但对多个等值条件查询则没有这样的限制。

规则6:查询条件中含有函数或表达式

如果查询条件中含有函数或表达式,则MySQL不会为这列使用索引(虽然某些在数学意义上可以使用)。

反思&扩展

如何创建合理的索引,索引如何优化?

喵呜面试助手:一站式解决面试问题,你可以搜索微信小程序 [喵呜面试助手] 或关注 [喵呜刷题] -> 面试助手 免费刷题。如有好的面试知识或技巧期待您的共享!

相关推荐
松涛和鸣2 分钟前
DAY67 IMX6 Development Board Configuration from Scratch
数据库·postgresql·sqlserver
路由侠内网穿透.6 分钟前
fnOS 飞牛云 NAS 本地部署私人影视库 MoonTV 并实现外部访问
运维·服务器·网络·数据库·网络协议
怣509 分钟前
MySQL表筛选分组全解析:排序、分组与限制的艺术
数据库·mysql
tsyjjOvO13 分钟前
JDBC(Java Database Connectivity)
java·数据库
陌上丨14 分钟前
如何保证Redis缓存和数据库数据的一致性?
数据库·redis·缓存
l1t27 分钟前
一个用postgresql的自定义函数求解数独的程序
数据库·postgresql·数独
IvorySQL1 小时前
改变工作方式的 PostgreSQL 实用模式
数据库·postgresql
Anarkh_Lee1 小时前
在VSCode中使用MCP实现智能问数
数据库·ide·vscode·ai·编辑器·ai编程·数据库开发
晓13131 小时前
第八章:Redis底层原理深度详细解析
数据库·redis·缓存
电商API&Tina1 小时前
电商数据采集 API 接口 全维度解析(技术 + 商业 + 合规)
java·大数据·开发语言·数据库·人工智能·json