当前位置: 首页 > news >正文

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。

http://www.gsyq.cn/news/93521.html

相关文章:

  • X荧光光谱仪怎么选?楚英豪JXF-8000 能量色散X荧光光谱仪 - 品牌推荐大师
  • 保姆级的MySQL执行计划(Explain)解读
  • [AI tradingOS] 市场数据系统 | 多交易所交易接口 | 适配器模式 - 教程
  • Plex动漫元数据终极解决方案:HAMA.bundle完整配置指南
  • librdkafka终极指南:5步搞定Kafka C客户端部署
  • python —— 偏函数 —— functools.partial 和 functools.partialmethod
  • 模型一上线就崩?你可能忽略了这三点
  • SeedVR2-7B:0.8秒重塑1080P视频,AI修复效率提升18倍
  • ImageProcessing:Ruby图像处理终极指南与性能优化方案
  • 轻量级AI新范式:重新定义企业智能部署的终极方案
  • AI人脸一致性生成技术深度解析:IP-Adapter-FaceID全系列实战指南
  • 3步构建波动率偏斜量化策略终极解决方案
  • “导师说‘开题报告像拼凑的PPT’?PaperZZ的‘AI开题工坊’:从选题模糊到逻辑闭环,用‘科研预演系统’把你的研究想法变成可执行的作战地图”
  • 稀土抑烟剂让 PVC 更安全
  • 2025年品牌命名公司推荐:专业命名机构权威榜单TOP5解析 - 品牌推荐
  • 3分钟快速集成eventpp:C++事件处理库的终极入门指南
  • SAE J1939协议终极指南:从入门到精通完整解析
  • 终极智能课程调度系统:5分钟快速部署完整指南
  • java计算机毕业设计少儿体育培训机构管理系统 青少年体适能培训中心综合运营平台 基于SpringBoot的少儿运动馆一站式管理系统
  • BloodHound图分析技术实战:从权限关系到攻击路径的深度挖掘
  • 5个超实用技巧:用cloc快速掌握代码统计分析方法
  • 高效构建AI应用:ag-ui TypeScript SDK完整实战指南
  • Qwen3Guard-Gen-8B:重新定义多语言AI安全防护新范式
  • 从零到一:M3 Pro芯片完美驾驭CosyVoice语音合成的实战指南
  • 重新定义数据可视化:Charticulator的终极图表设计指南
  • 搜维尔科技:推进帕金森病研究:MANUS数据手套可捕捉细微的手部运动变化
  • Atmosphere-NX 2168-0002错误代码:从诊断到修复的完整指南
  • 基于微信小程序的直播带货商品数据分析系统的设计与实现
  • WordPress 专业建筑行业公司网站主题模板 – Constructo v5.0.0
  • 估计一个三维结构的间距