MySQL慢查询分析与处理-第二篇

在第一篇介绍慢查询的文章中,提到了什么是慢查询,如何解读慢日志,如何使用pt-query-digest工具快速分析慢日志,本篇文章接着分享慢查询的常见原因和处理思路。

一、慢查询的常见原因

1、大事务

2、无主键表

3、未有效创建索引

4、统计信息未及时收集导致执行计划不准确

5、多个大表关联

6、大表DDL操作

7、操作系统负载高

8、内存或是磁盘故障导致os性能降低

二、慢查询的处理思路

步骤一:掌握慢SQL语句信息

1、了解该SQL是新上的还是以前就有

2、该SQL以前执行情况如何,现在执行耗时多少

3、该SQL是批量还是联机交易,能容忍的耗时是多少

4、该SQL单次提交是否有限制行数,是哪种类型的SQL

5、该SQL所在事务是否还有其他SQL,其他SQL涉及行数是多少

步骤二:分析慢SQL执行计划

通过explain语句,分析执行计划,检查是否走了索引,对比扫描行数和返回行数。若走了索引,分析索引区分度。

步骤三:优化慢SQL

sql优化和索引优化可以参考前面的文章。

相关推荐
Nturmoils11 小时前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波15 小时前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
Jim6001 天前
【吃透 MySQL InnoDB连载】第 1 章・解密线上数据库高频故障
mysql
TrisighT2 天前
Electron 跑在鸿蒙 PC 上,单窗口和多窗口内存差 800MB?我抓了 5 组数据
性能优化·electron·harmonyos
GreatSQL2 天前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql
倔强的石头_2 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
倔强的石头_5 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横5 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二5 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程