联合索引最左前缀匹配原则的成因
-
最左前缀匹配原则
- 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的查i优化器会帮你优化成索引可以识别的形式
- mysql会一直向右匹配直到遇到范围查询(>、<、between、like)就停止匹配,
-
联合索引(多个字段索引)中索引是从左到右依次使用,无法跳过,跳过的话就无法使用索引
- 因为内部索引是使用B+树的方式存储,从第一个字段开始排序,如果相等则按照第二个排序,如果不从第一个字段开始,依然需要扫描全表才有可能找到
个人博客:txyun5.linshiyou.cn