mysql联合索引

mysql联合索引
如:创建联合索引(c1,c2,c3,c4)
联合索引遵循最佳左前缀法则:
在等值查询的时候,就算字段顺序不和索引一致也没关系,mysql会进行优化。
在进行范围查询的时候,范围查询的字段后的索引全失效。比如where c1=“a1” and c2 = “a2” and c3>“a3”,那么c4失效。
索引列进行计算函数则失效。
like查询索引字段时如果%加在最左边失效。
不等于,not in , not exist会导致索引失效。
在order by和group by后边使用索引要按照定义索引的顺序,否则会失效,出现using filesort 和using temporary
如果带头大哥就使用了范围查询,那么索引直接无效
中间兄弟不能断:如果c1c2用于查询索引,c3到了orderby中,那么只用到c1和c2查询,c3用到排序,c4因为从c3这跳走了就没了。
c2在等值查询中出现,又在orderby中出现的,且位于c3之后,不会出现问题,因为c2是常量,被优化

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值