我们在使用联合索引时需要注意以下两点:
- 最左前缀法则
如果索引了多列(联合索引),要遵守最左前缀法则。
最左前缀法则指的是查询从索引的最左列开始,并且不跳过索引中的列。如果跳跃某一列,索引将会部分失效(后面的字段索引失效)。
# 例如我们在前面建立了一个idx_user_pro_age_status索引包含了pro,age,status三个列
# 当我们从左边往右边逐渐使用时不会产生错误:
explain select * from tb_user where profession = '软件工程' and age = 31 and status= '0';
explain select * from tb_user where profession = '软件工程' and age = 31;
explain select * from tb_user where profession = '软件工程';
# 但当我们中间省略一列,或者缺少最前面的列,后面的索引列将不再被使用
explain select * from tb_user where age = 31 and status = '0';
explain select * from tb_user where status = '0';
注意:
- where后的索引顺序不受约束,最前面的索引可以放在where的任意位置不受影响