单表 范围查询 后面的索引会失效
双表 左右连接建立索引互相使用
三表 用小结果集驱动大表结果, 先优化括号里面的SQL, 保证JOIN被驱动的表上ON字段有索引
索引失效(常见原因)
全职匹配 最佳左前法则 如果是复合索引,确保最左侧索引列一定要有 若无,全表扫描 索引列上不计算 不在索引列上做任何操作, 计算,函数,(自动or手动)类型转换,会导致索引失效还全表扫描 比如 left() 范围之后全失效 存储引擎不能使用索引中范围条件右边的列 索引失效 比如复合A, B C3列 若条件B > 20 则 C列失效 尽量使用覆盖索引,减少select * 在使用!= 或者 <>的时候无法使用索引,会导致全表扫描 is null, is not null也无法使用索引 like百分加右边 like 以通配符开头 ‘%sdf’, 索引失效,全表扫描 字符串不加单引号,索引失效 少用or, 用他来连接时索引失效
索引优化
单值索引,尽量选择对query过滤好的索引
组合索引,过滤性比较好的字段放在索引前面, 选择索引列时尽量包含where更多的字段
你对SQL的优化怎么试.
1 观察跑1天,看看生产慢的SQL
2 开启慢查询日志,比如超过5秒的慢sql抓取出来
3 explain+慢SQL分析
4 show profile 查询SQL在Mysql服务器的执行细节
5 DBA进行SQL数据库服务器的参数调优
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)