如何开启MySQL的慢查询日志

说明:如果需要查看某一条SQL查询速度慢,并对慢的SQL进行优化,那么开启MySQL慢查询日志是一定要做的事情,本文介绍如何开启MySQL的慢查询日志;

查看MySQL慢查询是否开启

首先,输入下面的命令,查看MySQL慢查询的配置;

sql 复制代码
show variables like 'slow_query_log';

OFF,表示未开启;

开启MySQL慢查询

输入下面的SQL,开启MySQL的慢查询;

sql 复制代码
# 开启慢查询
set GLOBAL slow_query_log = on;

查看慢查询设置的时间,单位是秒,默认的是10秒;

如果需要修改,可以输入下面这个SQL进行修改;

sql 复制代码
# 修改慢查询的时间为5秒,即超过5秒为慢查询
set long_query_time = 5;

修改成5秒;

查看效果

现在,我这里有一张1000万条数据的表,根据username查询一条数据,看下执行时间;

根据用户名查询记录;

26秒,无疑是慢查询;

找到MySQL的安装目录,在data文件夹下面有一个计算机名-slow.log的文件,就是慢查询的日志文件;

打开后,可以看到这几次慢查询的日志信息,其中方框内为一次查询信息,注意这里Time记录的时间是0时区的时间,需要加上对应时区才是当地时间;

找到慢SQL后,然后进行优化,向我这个,只要把username加上索引即可,参考:MySQL数据库给表添加索引

相关推荐
l***217810 小时前
MySQL--》理解锁机制中的并发控制与优化策略
数据库·mysql·oracle
chenyuhao202410 小时前
MySQL索引特性
开发语言·数据库·c++·后端·mysql
5***r93510 小时前
SQL实现md5加密方法
数据库·sql
i***778010 小时前
mysql 迁移达梦数据库出现的 sql 语法问题 以及迁移方案
数据库·sql·mysql
5***E68510 小时前
mysql重置root密码(适用于5.7和8.0)
数据库·mysql·adb
q***697710 小时前
使用 Qt 插件和 SQLCipher 实现 SQLite 数据库加密与解密
数据库·qt·sqlite
t***821110 小时前
【Oracle11g SQL详解】日期和时间函数:SYSDATE、TO_DATE、TO_CHAR 等
数据库·sql
Fantasy丶夜雨笙歌10 小时前
SQL综合实战:从基础约束到高级应用的完整指南
数据库·sql
T***742510 小时前
redis连接服务
数据库·redis·bootstrap
蜡笔小炘11 小时前
Mysql 结课项目报告
数据库·adb