简要描述MySQL数据库联合索引的命中规则

  1. mysql的联合查询索引尊姓最左前缀匹配规则,即从联合索引的最左列开始向右匹配,知道遇到匹配的终止条件。例如联合索引(col1、col2、col3),where的条件为col1=a AND col2=`b,可命中该联合索引的(col1、col2)前缀部分,where条件为 col2=‘a’ AND col3='c’的时候,不符合左前缀匹配,不能命中该联合索引
  2. 匹配终止条件为范围操作符(如>、<、 between、like等)或函数等,不能应用索引的情况,例如联合索引(col1、col2、col3),where大的条件为col1=‘a’ AND col2>1 AND col3=‘c’,在col2列上为范围查询,匹配会终止,只能匹配到col1,不能匹配到(col1, col2, col3).
  3. where条件中的顺序不影响索引命中。例如联合索引(col1, col2, col3), where条件为col3=c AND col2=b AND col1=a, MySQL优化器会自行进行优化,可命中联合索引(col1, col2, col3).
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值