MySQL最左前缀原则面试题分享

**

最左前缀总结:

**
如果建立索引(a,b,c),此时相当于存在三种情况会建立并使用索引–(a),(a,b),(a,b,c)
针对于范围查询–范围列可以用到索引(必须是最左前缀),但是范围列之后无法用到索引,同时,索引最多用于一个范围列,一次如果查询条件中有两个范围列则无法全用到索引
例如:a = 1 (使用索引)
a = 1 and b = 2 或者 b = 2 and a = 1 (使用索引,=和in可以乱序,比如a=1 and b=2 and c=3 建立(a,b,c)索引可以任意顺序,mysql查询优化器会自动优化成索引需求的样子)
a = 1 and b = 2 and c = 3 (使用索引)
a = 1 and c = 3 (使用索引,此处只会使用a的单列索引,c列无法使用索引)
b = 2 and c = 3 (不使用索引,不满足上述索引顺序)
a = 1 and b < 2 (使用索引,a,b字段会使用索引)
a = 1 and b < 2 and c = 3 (使用索引,a,b字段会使用索引,c列无法使用索引)
a = 1 and b = 2 and c < 3 (使用索引,a,b,c都会使用索引)
c < 3 and a = 1 and b = 2 (不使用索引,因为c开头不满足a的最左前缀原则,即使a 和 b可以互换位置也没法换到c 的前面)

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值