Mysql防止索引失效原则
Posted -零
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mysql防止索引失效原则相关的知识,希望对你有一定的参考价值。
防止索引失效原则
1.当你使用索引的时候,最好能够把你建立的索引的字段都给用到。不仅可以提供查询的效率。
2.最佳左前缀法则,意思就是当你如果有建立过多个字段索引的组合索引的时候,最要遵循最左前缀法则,指的是查询从索引的最左前列开始并且不能跳过索引中的列。
原则:
- 第一个索引不能掉
- 中间索引不能掉
3.不在索引列上做任何操作(计算、函数(自动or手动)类型转换),会导致索引失效而转向全表扫描。
4.存储引擎不能使用索引中范围右列的列,范围之后索引全失效。
5.尽量使用覆盖索引(只访问索引的查询(索引列和查询一致)),减少select *。
6.mysql在使用不等于(!=或者<>)的时候无法使用索引会导致全表扫描。
7.is null,is not null也无法使用索引,所以表中的数据应该不能为NULL。
8.like以通配符开头(\'%abc...\')或者(\'%abc%...\'),mysql索引失效会变成全表扫描的操作,使用(\'abc%\')索引不失效。
9.字符串不加单引号索引失效。
10.少用or,用它来连接时会索引失效。
小总结:
refer:
https://blog.csdn.net/weixin_34122810/article/details/89534628
以上是关于Mysql防止索引失效原则的主要内容,如果未能解决你的问题,请参考以下文章
MySQL 进阶 索引 -- 索引使用原则(验证索引效率最左前缀法则范围查询索引失效情况SQL提示覆盖索引前缀索引单列索引与联合索引)索引设计原则
MySQL 高级--优化 —— 创建索引原则使用场景和索引失效的情况
MySQL 进阶 索引 -- 索引使用原则(验证索引效率最左前缀法则范围查询索引失效情况SQL提示覆盖索引前缀索引单列索引与联合索引)索引设计原则