mysql8查看执行sql历史日志、慢sql历史日志,配置开启sql历史日志general_log、慢sql历史日志slow_query_log

0.本博客sql总结

sql 复制代码
-- 1.查看参数
-- 1.1.sql日志和慢sql日志输出方式(TABLE/FILE)。global参数
SHOW GLOBAL  VARIABLES LIKE 'log_output';
-- 1.2.sql日志开关。global参数
SHOW GLOBAL  VARIABLES LIKE 'general_log%';
-- 1.3.慢sql日志开关。global参数
SHOW GLOBAL  VARIABLES LIKE 'slow_query_log%';
-- 1.4.慢sql日志时间限制
SHOW SESSION VARIABLES LIKE 'long_query_time';
SHOW GLOBAL  VARIABLES LIKE 'long_query_time';

-- 2.设置参数
-- 2.1.sql日志和慢sql日志输出方式(TABLE/FILE)。global参数
SET GLOBAL  log_output = 'TABLE';
SET PERSIST log_output = 'TABLE';
-- 2.2.sql日志开关。global参数
SET GLOBAL  general_log = 'ON';
SET PERSIST general_log = 'ON';
-- 2.3.慢sql日志开关。global参数
SET GLOBAL  slow_query_log = 'ON';
SET PERSIST slow_query_log = 'ON';
-- 2.4.慢sql日志时间限制。session+global级别参数
SET SESSION long_query_time = 10;
SET GLOBAL  long_query_time = 10;
SET PERSIST long_query_time = 10;

-- 3.查询sql历史
-- 3.1.sql历史
-- TRUNCATE mysql.general_log;
SELECT *, CONVERT(argument USING utf8mb4) as argument2 FROM mysql.general_log ORDER BY event_time DESC LIMIT 1000;
-- 3.2.慢sql历史
-- TRUNCATE mysql.slow_log;
SELECT *, CONVERT(sql_text USING utf8mb4) as sql_text2 FROM mysql.slow_log ORDER BY start_time DESC LIMIT 1000;

1.概要

  • mysql8默认未开启sql历史日志。
  • mysql8默认已开启慢sql历史日志。

2.设置

2.1.参数说明

  • log_output: sql日志输出位置
    • FILE:输出到文件。默认值
    • TABLE:输出到表。
      • mysql.general_log
      • mysql.slow_log
  • general_logsql历史日志开关。默认为OFF
  • slow_query_log慢sql历史日志开关。默认为ON
  • long_query_time慢sql历史时长,即超过此时长才记录。默认为10

2.2.查看参数

2.2.1.sql日志和慢sql日志输出方式(TABLE/FILE)。global参数

sql 复制代码
SHOW GLOBAL  VARIABLES LIKE 'log_output';

2.2.2.sql日志开关。global参数

sql 复制代码
SHOW GLOBAL  VARIABLES LIKE 'general_log%';

2.2.3.慢sql日志开关。global参数

sql 复制代码
SHOW GLOBAL VARIABLES LIKE 'slow_query_log%';

2.2.4.慢sql日志时间限制。session+global级别参数

sql 复制代码
SHOW SESSION VARIABLES LIKE 'long_query_time';
SHOW GLOBAL  VARIABLES LIKE 'long_query_time';

2.3.修改参数

2.3.1.设置sql日志和慢sql日志输出方式(TABLE/FILE)。global参数

sql 复制代码
SET GLOBAL  log_output = 'TABLE';
SET PERSIST log_output = 'TABLE';

2.3.2.设置.sql日志开关。global参数

sql 复制代码
SET GLOBAL  general_log = 'ON';
SET PERSIST general_log = 'ON';

2.3.3.设置.慢sql日志开关。global参数

sql 复制代码
SET GLOBAL  slow_query_log = 'ON';
SET PERSIST slow_query_log = 'ON';

2.3.4.设置.慢sql日志时间限制。session+global级别参数

sql 复制代码
SET SESSION long_query_time = 10;
SET GLOBAL  long_query_time = 10;
SET PERSIST long_query_time = 10;

3.查sql日志和慢sql日志

3.1.查日志文件。

  • log_output = 'FILE'

3.2.查日志表。

  • log_output = 'TABLE'

  • 查看sql历史记录(注意字符编码)

sql 复制代码
-- 3.1.sql历史
-- TRUNCATE mysql.general_log;
SELECT *, CONVERT(argument USING utf8mb4) as argument2 FROM mysql.general_log ORDER BY event_time DESC LIMIT 1000;
-- 3.2.慢sql历史
-- TRUNCATE mysql.slow_log;
SELECT *, CONVERT(sql_text USING utf8mb4) as sql_text2 FROM mysql.slow_log ORDER BY start_time DESC LIMIT 1000;
  • general_log
  • slow_log
相关推荐
阿华的代码王国5 分钟前
MySQL ------- 索引(B树B+树)
数据库·mysql
Hello.Reader33 分钟前
StarRocks实时分析数据库的基础与应用
大数据·数据库
执键行天涯35 分钟前
【经验帖】JAVA中同方法,两次调用Mybatis,一次更新,一次查询,同一事务,第一次修改对第二次的可见性如何
java·数据库·mybatis
liupenglove40 分钟前
golang操作mysql利器-gorm
mysql·golang
yanglamei19621 小时前
基于GIKT深度知识追踪模型的习题推荐系统源代码+数据库+使用说明,后端采用flask,前端采用vue
前端·数据库·flask
Darling_001 小时前
LeetCode_sql_day28(1767.寻找没有被执行的任务对)
sql·算法·leetcode
zxrhhm1 小时前
SQLServer TOP(Transact-SQL)
sql·sqlserver
叫我:松哥1 小时前
基于Python flask的医院管理学院,医生能够增加/删除/修改/删除病人的数据信息,有可视化分析
javascript·后端·python·mysql·信息可视化·flask·bootstrap
工作中的程序员1 小时前
ES 索引或索引模板
大数据·数据库·elasticsearch
严格格1 小时前
三范式,面试重点
数据库·面试·职场和发展