**
最左前缀总结:
**
如果建立索引(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 的前面)