news 2026/4/23 18:52:57

MySQL数据库慢SQL监听

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL数据库慢SQL监听

在MySQL数据库中,自带了慢SQL的监听和记录功能,下面演示下如何如何来查看。当前数据库版本为8.0.42

开启慢SQL记录

show variables like '%query%';

通过执行上面的语句,可以看到当前数据库的情况(默认,没有修改过)

如果查询到的结果是slow_query_log=OFF,表示慢SQL记录功能未开启,手动开启即可,具体操作如下:

#开启慢SQL日志功能
set GLOBAL slow_query_log=on;


#慢SQL执行时间阈值,单位(秒) ,1毫秒=0.001
#不建议超过300ms,最终结果视情况而定
set global long_query_time=0.001;


#指定慢SQL文件名为slow-sql,慢SQL日志保存在mysql/data目录下
set global slow_query_log_file="slow-sql.log";

long_query_time默认值是10秒钟,把它改成0.001,为了方便下面的演示。

同时把slow_query_log_file的文件名称改成因为,中文会乱码。

修改配置后,需要重启navicat,否则不生效。

将慢SQL的定义改成0.001秒(1毫秒)之后,再次查询配置信息:

查看慢SQL记录

在数据库执行一个查询,然后观察慢SQL文件记录的信息。

任意执行一个查询,只要查询时间超过1毫秒即可:

执行完成,找到MySQL安装目录,到到data目录下面的slow-sql.log文件

打开文件,找到最后一次的记录

下面对其中的内容进行分析,对每个参数进行说明:

其中需要重点关注的两个参数是 Time(SQL执行时间),Rows_examined(扫描的行数),这两个值越大,说明SQL执行效率越低,需要进行优化。

MySQL优化技巧,可以参考下面的文章:

https://blog.csdn.net/liangmengbk/article/details/155714304?spm=1001.2014.3001.5501

查看哪些SQL没有使用到索引

除了记录慢SQL能到知道哪些SQL语句执行效率低外,还有一种方式可以达到类似的效果,那就是把没有使用到索引的SQL记录下来。没有使用到索引的SQL也是我们可以进行优化的重点对象。

首先是在MySQL中要开启 未使用索引的语句记录 开关,命令如下:

set global log_queries_not_using_indexes=on;

执行这个命令打开这个开关,如果执行的SQL没有使用到任何索引,则自动会被记录下来(内容也是放在slow-sql.log文件中,和慢SQL放在一个文件的),方便分析。

开启后,也是需要重启navicat,才能生效。

为了验证能准确记录相关信息,先把慢SQL的时间改成10秒,暂时不记录慢SQL,观察slow-sql.log文件的内容。

下面执行一个查询

因为这个查询使用了like关键字,且前后都有%,会导致原有的索引失效,也就是说这个SQL肯定没有用到索引,打开slow-sql.log文件看下记录的内容。

确实被记录下来了,因为当前设置的慢SQL标准是10秒,而该SQL执行仅花费0.0014秒,所以它就是因为没有用到索引而记录的。

同时还发现它的下面有两个SQL也被记录下来了,这两个SQL是MySQL数据库系统表的相关SQL,虽然不是我们人为执行的,但是以为它没有用到索引,所以也被记录下来,可以不用关注。目前还没有办法做到只记录我们自己执行的SQL,而避开MySQL系统的SQL。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 12:35:21

黑马头条-再回首

黑马头条 ps : 学习代码架构设计 学习场景的封装抽离 学习并发处理 时隔多年,再次学习,查看当初写的代码,也许有不同的感受 项目概述功能用例 用户案例用例自媒体人ADMIN用例图架构设计研究点 表的设计,功能的流程&…

作者头像 李华
网站建设 2026/4/23 11:25:46

Vuetify VCalendar:构建现代化日程管理系统的完整解决方案

Vuetify VCalendar:构建现代化日程管理系统的完整解决方案 【免费下载链接】vuetify 🐉 Vue Component Framework 项目地址: https://gitcode.com/gh_mirrors/vu/vuetify Vuetify作为Vue.js生态系统中最受欢迎的UI框架,其VCalendar组件…

作者头像 李华
网站建设 2026/4/23 9:33:40

Tron自动化清理工具:Windows系统维护的终极指南

在当今数字化时代,计算机系统的稳定性和安全性至关重要。Tron作为一个强大的自动化PC清理脚本,专门为Windows系统提供全面的清理、消毒和维护解决方案。这个免费开源工具通过多阶段处理流程,帮助用户彻底解决系统运行缓慢、安全威胁和垃圾文件…

作者头像 李华
网站建设 2026/4/23 10:50:37

命令行开发者的终极效率工具:openapi-generator-cli 完全指南

命令行开发者的终极效率工具:openapi-generator-cli 完全指南 【免费下载链接】awesome-shell A curated list of awesome command-line frameworks, toolkits, guides and gizmos. Inspired by awesome-php. 项目地址: https://gitcode.com/gh_mirrors/aw/awesom…

作者头像 李华
网站建设 2026/4/23 10:50:28

7个让Obsidian笔记焕然一新的实用美化技巧

7个让Obsidian笔记焕然一新的实用美化技巧 【免费下载链接】awesome-obsidian 🕶️ Awesome stuff for Obsidian 项目地址: https://gitcode.com/gh_mirrors/aw/awesome-obsidian 你是否觉得自己的Obsidian笔记界面看起来有些单调乏味?想要打造一…

作者头像 李华