0

0

SQL慢查询怎么排查_详细步骤拆解实现完整应用场景【技巧】

舞姬之光

舞姬之光

发布时间:2025-12-16 21:39:29

|

959人浏览过

|

来源于php中文网

原创

SQL慢查询排查核心三步:定位慢SQL、分析执行计划、针对性优化。先通过日志或监控(如MySQL slow_query_log、PG log_min_duration_statement)捕获慢SQL;再用EXPLAIN查看type、rows、Extra、Index Key Usage等关键指标;最后按没走索引、索引失效、数据量大、统计信息过期四类精准优化,并验证固化。

sql慢查询怎么排查_详细步骤拆解实现完整应用场景【技巧】

SQL慢查询排查核心就三步:定位慢SQL、分析执行计划、针对性优化。不靠猜,不靠经验堆砌,而是用数据库自带工具+逻辑推演,快速锁定瓶颈点。下面按真实排查流程拆解,每一步都带操作命令和判断依据。

第一步:从日志或监控里揪出慢SQL

慢SQL得先看见,才能处理。不同数据库入口不同:

  • MySQL:打开slow_query_log,设置long_query_time=1(单位秒),日志默认存/var/lib/mysql/slow.log;也可用SHOW PROCESSLIST实时看正在跑的长事务
  • PostgreSQL:配置log_min_duration_statement = 1000(毫秒),日志路径看log_directorylog_filename
  • 生产环境建议接Prometheus+Grafana,用pg_stat_statements(PG)或performance_schema.events_statements_summary_by_digest(MySQL)聚合统计TOP耗时SQL

第二步:用EXPLAIN看执行计划,盯死这4个关键指标

拿到慢SQL后,别急着改,先加EXPLAIN FORMAT=TREE(MySQL 8.0+)或EXPLAIN (ANALYZE, BUFFERS)(PG),重点看:

  • type / Join Type:出现ALL(全表扫描)或index(全索引扫描)基本就是没走对索引
  • rows / Rows Removed by Filter:预估扫描行数远大于实际返回行数,说明过滤条件没生效或索引覆盖不全
  • Extra:看到Using filesortUsing temporary大概率要优化排序或分组逻辑
  • Index Key Usage:确认key字段是否命中预期索引,key_len是否合理(比如varchar(255)只用了前10个字节,可能前缀索引太短)

第三步:按常见瓶颈类型精准优化

不是所有慢都靠加索引解决,得分类施策:

Originality AI
Originality AI

专门为网络出版商设计的抄袭和AI检测工具

下载
  • 没走索引:检查WHERE字段是否有函数操作(如WHERE YEAR(create_time) = 2024)、隐式类型转换(字符串ID用数字查)、OR条件未统一索引路径
  • 索引失效:联合索引最左匹配被破坏(INDEX(a,b,c),但查询只用了b = ?)、范围查询后列无法走索引(a = ? AND b > ? AND c = ?中c不生效)
  • 数据量大但必须查:考虑分页优化(用WHERE id > last_id LIMIT 20替代OFFSET)、冷热分离(把历史归档表单独拆出)、读写分离分摊压力
  • 统计信息过期:执行ANALYZE TABLE xxx(MySQL)或ANALYZE xxx(PG),让优化器重算成本模型

第四步:验证+固化,避免反复踩坑

改完不是结束,得闭环验证:

  • 在测试库用EXPLAIN ANALYZE对比前后执行计划和实际耗时
  • 上线前做压测,观察QPS、连接数、CPU是否突增(有时优化了单条,却引发锁竞争)
  • 把修复后的SQL和对应索引语句记入团队Wiki,标注适用场景(比如“该索引仅适用于status IN (1,2)且create_time倒序分页”)
  • 在CI流程中加入SQL审核(用soararcher),自动拦截全表扫描、缺失WHERE、ORDER BY无索引等高危写法

基本上就这些。慢查询不是玄学,是可测量、可追踪、可复现的问题。工具摆在那里,逻辑链路也清晰,卡住的往往不是技术,而是有没有耐心把EXPLAIN输出一行行读明白。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

686

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

325

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

348

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1137

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

359

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

737

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

577

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

420

2024.04.29

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

41

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.9万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 810人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号