MySQL数据库索引的最左匹配原则((a),(a,b),(a,b,c)都能用到索引,(a,c)呢?)

一. 联合索引说明

  • 建立三个字段的联合索引
  • 联合索引(a,b,c)相当于建立了索引:(a),(a,b),(a,b,c)

二. 那ac是否能用到索引呢?

先给出结论:a可以命中联合索引(a,b,c),c无法命中,所以ac组合无法命中联合索引。

1.建立abc联合索引(province,city,district)
在这里插入图片描述

  • ac索引查询
SELECT * FROM user_address WHERE province = '广东' 
AND district = '南雄市'

在这里插入图片描述

显示查询范围是ALL

2.直接建立ac两个字段得联合索引
在这里插入图片描述

SELECT * FROM user_address WHERE province = '广东' 
AND district = '南雄市'

在这里插入图片描述

查询结果是ref走了索引,扫描的行数也从21行变成了13行

3.ab索引查询
在这里插入图片描述

查询范围为ref

结论

  • abc联合索引,ac中的c不能命中这三个字段的联合索引,a可以命中,所以possible_keys列会显示使用了联合索引

三. 思考

abc索引,acb会走索引吗?

  • 最左前缀匹配原则,mysql会一直向右匹配直到遇到范围查询(>、<、between、like)就停止匹配
  • 比如a=3 and b=4 and c>5 and d=6如果建立(a,b,c,d)顺序的索引,d是用不到索引的,如果建立(a,b,d,c)的索引则都可以用到,a,b,d的顺序可以任意调整。
  • =和in可以乱序,比如a=1 and b=2 and c=3建立(a,b,c)索引可以任意顺序,mysql的查询优化器会帮你优化成索引可以识别的形式

四. 最左匹配原则的成因

  • 因为联合索引,如:abc,联合索引可以理解为有序的且形成的基础是建立在a上的,从a上建立b,b上建立c,所以必须要按照顺序来
  • 可以简单理解为:先对a排序建立索引,再在a的基础上对b进行排序,再是c
  • 所以联合索引在遇到范围查询,后面的索引会失效。
  • 11
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
MySQL索引的最匹配原则是指在使用复合索引进行查询时,必须按照索引的最边的列开始匹配,然后再逐个匹配剩余的列。如果不按照索引的最边的列进行匹配MySQL将无法利用索引,而需要进行全表扫描,对性能会产生很大的影响。\[1\]\[2\]\[3\] 举个例子,如果有一个由(a, b, c)组成的复合索引,那么在查询时必须先使用a进行过滤,然后才能使用b或c进行过滤,即使b或c也属于索引的一部分。如果不按照这个顺序进行查询,MySQL将无法使用索引进行优化。\[3\] 需要注意的是,最前缀匹配原则只适用于联合索引,而不适用于单列索引。在建立联合索引时,最前缀匹配原则可以帮助我们优化查询性能,提高查询效率。\[2\] #### 引用[.reference_title] - *1* *3* [MySQL的最匹配原则](https://blog.csdn.net/weixin_52060913/article/details/130615245)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Mysql 联合索引匹配原则](https://blog.csdn.net/Klaus_S/article/details/130972214)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值