如何开启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数据库给表添加索引

相关推荐
数据库小学妹3 分钟前
分布式数据库架构演进:从集中式到分布式,三大路线一次讲清楚
数据库·分布式·数据库架构
洛水水12 分钟前
redis缓存:雪崩、穿透、击穿详解
数据库·redis·缓存
暴躁小师兄数据学院23 分钟前
【AI大数据工程师特训笔记】第01讲:数据库基本概念
大数据·数据库·笔记
Harm灬小海30 分钟前
【云计算学习之路】企业常用服务搭建:MySQL 8.0
linux·运维·学习·mysql·云计算
杨云龙UP31 分钟前
Oracle Flashback Query 实战练习:误更新、误删除数据如何快速找回?
linux·运维·数据库·sql·oracle·flashback
basketball61632 分钟前
SQL 条件聚合 使用方法总结
服务器·数据库·sql
洛水水37 分钟前
Redis 内存淘汰策略详解
数据库·redis·缓存
一只fish37 分钟前
Oracle官方文档翻译《Database Concepts 26ai》第12章-数据并发与一致性
数据库·oracle
Crazy_eater1 小时前
Mysql(1)
数据库·mysql