前言
SQL调优是面试中经常爱问的问题,这个问题可以考察一个候选人对于SQL的整体性能优化的理解和掌握程度,今天我么你来聊一聊如何继续宁SQL调优。
步骤
一般来说,SQL调优需要从以下几个方面和步骤入手。
首先,需要先发现问题,尤其是在面试中,最好是结合业务说明,比如是某一次线下报警出现了慢SQL,或者是接口RT比较长,做了性能分析发现瓶颈是在SQL查询上面都可以。但是不管怎么样,一定要有背景。
有了问题之后,那就是问题的分析了。
首先需要定位到具体的SQL语句,这个可以通过各类监控平台或者工具来实现,通过定位到SQL语句之后,我们就知道具体是哪张表、哪个SQL慢了。
那接下来就是进行分析了,一般一个SQL慢,可能有以下几种原因
- 索引失效
- 多表join
- 查询字段太多
- 表中数据量太大
- 索引区分度不高
- 数据库连接数不够
- 数据库的表结构不合理
- 数据库I0或者CPU比较高
- 数据库参数不合理
- 事务比较长
- 锁竞争导致的等待
所以,一次完整的SQL调优,一般需要考虑以上几个因素,一般会涉及到其中的一个或者多个问题。那么就逐个优化。
1、索引失效
首先,索引失效的问题一般是先通过执行计划分析是否走了索引,以及所走的索引是否符合预期,如果因为索引设计的不合理、或者索引失效导致的,那么就可以修改索引,或者修改SQL语句。或者强制执行使用某个索引。具体可以参考:
索引失效的问题如何排查?
MySQL的索引失效是一个比较常见的问题,这种情况一般会在慢SQL发生时需要考虑,考虑是否存在索引失效的问题。
在排查索引失效的时候,第一步一定是找到要分析的SQL语句,然后通过explain查看他的执行计划。主要关注type、key和extra这几个字段。