news 2026/4/17 13:21:01

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/17 14:15:44

终极SQL Server JDBC驱动:快速搭建Java数据库连接的完整指南

SQL Server JDBC驱动程序4.0版本是专为Java应用程序设计的数据库连接利器,它提供了与Microsoft SQL Server数据库的无缝连接支持,让开发者能够轻松实现企业级应用的数据访问需求。本驱动支持JDBC 4.0标准,为你的项目带来稳定可靠的数据库连接…

作者头像 李华
网站建设 2026/4/18 7:01:51

Lucky终极使用攻略:5分钟掌握公网神器核心功能

还在为复杂的网络配置发愁?Lucky公网神器让你的网络管理变得简单高效!本文将带你深度解析Lucky的五大核心功能,从动态域名解析到端口转发,从远程唤醒到反向代理,让你真正掌握这款强大的网络工具。 【免费下载链接】luc…

作者头像 李华
网站建设 2026/4/17 7:06:06

ARMv8架构终极指南:从入门到精通完整教程

ARMv8架构终极指南:从入门到精通完整教程 【免费下载链接】ARMv8架构参考手册下载分享 ARMv8架构参考手册下载 项目地址: https://gitcode.com/Open-source-documentation-tutorial/1df35 快速掌握ARMv8架构核心概念与方法 ARMv8-A架构作为现代计算领域的核…

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

电铸铁试验平台的特性与优势

电铸铁试验平台的特性与优势电铸铁试验平台采用电化学沉积工艺制造,具有高硬度、高耐磨性和优异的尺寸稳定性。其表面经过特殊处理,可达到镜面级光洁度,适合精密测量和实验需求。电铸铁材质具备良好的抗腐蚀性能,能在潮湿环境中长…

作者头像 李华
网站建设 2026/4/18 5:33:12

Starship命令行提示符:重新定义终端交互体验的革命性工具

Starship命令行提示符:重新定义终端交互体验的革命性工具 【免费下载链接】starship ☄🌌️ The minimal, blazing-fast, and infinitely customizable prompt for any shell! 项目地址: https://gitcode.com/GitHub_Trending/st/starship 在当今…

作者头像 李华