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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
2019-01-12 NumPy学习(让数据处理变简单)
2019-01-12 python命令行解析模块--argparse