1.针对联合索引查询的时候要遵循最左前缀原则,查询条件中带头字段一定要写上,中间字段不能断,要连续,例如:
2.不要在索引列上做任何操作(计算、函数、(自动或手动)类型转换),例如下面会导致索引失效:
3.存储引擎不能使用索引中范围条件右边的列,这样会导致范围右边列索引用不上,例如:
4.减少select * 的使用,尽量使用覆盖索引(只访问索引的查询索引列和查询列一致),例如:
5.mysql在使用不等于(!=或<>) 的时候无法使用索引,会导致全表扫描,例如:
6.mysql中过滤的时候使用is null或者is not null也会无法使用索引,例如:
7.like以通配符开头(’%abc…’)的时候,mysql索引会失效变为全表扫描,例如:
8.查询条件中的字符串不加单引号的时候,索引会失效,例如:
9.少用or,用它来连接是会导致索引失效,例如: