导语:前一段时间做的一个某干部考核系统,本身系统方面没什么技术难题,主要难点在于项目的业务逻辑比较复杂,所以就设计到了各种查询,在实际使用场景中还是碰到了慢sql问题,前前后后总结了一些,并且结合上一篇sql语句执行顺序问题,食用更佳!
个人认为导致SQL语句慢大致可以分为两类:
1.查询所需的数据过大:(也就是查询的数据量确实过大)
-
根据具体情况决定将sql写成一个复杂查询,还是多个简单查询(在Java程序合并结果集)
-
分解关联查询(分为单表查询,将结果集在Java应用程序进行关联)
-
尽量让二级索引实现覆盖索引,避免回表
2.SQL语句问题:(不合理的sql语句导致的没走索引等问题)
-
Where 语句方面:
- 应尽量避免在where子句中对字段进行函数操作;
- 尽量避免在 where 子句中对索引字段进行计算操作;
- 应尽量避免在 where 子句中使用 != 或 <> 操作符;
- 应尽量避免在 where 子句中对字段进行 null 值判断(IS NULL);
- 应尽量避免在 where 子句中使用 or 来连接条件
- 可以使用 exist 和not exist代替 in和not in
- Having可以用where代替,如果无法代替可以分两步处理
- 模糊查询尽量少用左%或者左右都是%
- Select语句
- 尽量不要使用select * from table这种方式;把要查询的具体字段列出来,不要返回任何用不到的字段
- 其他方面(将持续更新...)