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