mysql时间段查询语句_MySQL 如何查看慢查询语句

为保证数据库性能,我们要对慢查询语句进行优化。本文分享 Mysql 数据库如何查看慢查询语句。

Mysql 默认情况下记录慢查询语句的功能是关闭的。用如下命令查看:

SHOW VARIABLES LIKE '%slow_query_log%';

运行后效果如下:

49a4ec407fcedb1c024c72e5a16ac0e2.png

slow_query_log 的值代表是否开启记录慢查询语句的功能,

slow_query_log_file 的值代表慢查询语句将会记录的文件名。

将 slow_query_log 的值设为 1 即可开启该功能,语句如下:

SET GLOBAL slow_query_log=1;

运行效果如下:

7bd9eac50e5d3cb6dc07d43c8e2b1445.png

再次查询:

37585440fdd787b83a9bb3e38a4ec7bb.png

可见 slow_query_log 的值为 ON,表示该功能已经开启。

那么运行时间多长的语句会被记录进去呢?也就是说多慢才算慢呢?

这个时间由 long_query_time 记录, 用如下命令可查:

SHOW VARIABLES LIKE 'long_query_time%';

运行效果如下:

b9bdffb2fb105fe9a6502fe1d21086aa.png

默认为10秒,超过 10 秒将会被记录下来。

用如下语句测试一下:

SELECT sleep(11);

11 秒后显示如下效果:

643890a11b83d2d41c9de01334d5cdfe.png

查看 slow_query_log_file 所指定的文件:

099cdbd935cf7043e7ad2ae3e00805f4.png

可以看到 SELECT sleep(11); 已经被记录了。

我们可以自己设置 long_query_time 的值,例如设置成 3 秒:

SET GLOBAL long_query_time=3;

运行效果:

293f343b3cece3b8ee836a281fc5e6a9.png

查询:

175a62a126b62741efa8b5f712deed2f.png

但还是显示 10,并没有显示 3,别急,再开一个新的查询窗口查看:

01383ecde8a639249d2f72c0e5d88d14.png

则可看到已经改为 3。

此时在新查询窗口中查:

SELECT sleep(4);

则会被记录到慢查询日志中:

03d41ecb8db44aba5f4204cb594fd46b.png

注意以上对变量的设置在 Mysql 服务器重启之后则失效。

要想永久生效,在 mysql 配置文件中修改对应的属性值即可。

本次分享完毕,感谢阅读,欢迎讨论,欢迎批评指证!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值