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
相关推荐
云和数据.ChenGuang几秒前
运维面试题之oracle和mysql单表最大容量
运维·mysql·oracle
q***92516 分钟前
sql实战解析-sum()over(partition by xx order by xx)
数据库·sql
gladiator+8 分钟前
Redis之BigKey的常见问题以及大厂相关面试题
java·数据库·redis
合方圆~小文12 分钟前
AI摄像头精准识别技术依赖于深度算法
数据结构·数据库·数码相机·模块测试
tanxiaomi24 分钟前
Redis相关面试题
数据库·redis·缓存
钮钴禄·爱因斯晨1 小时前
【探索实战】KuratorGitOps 多环境配置管理与合规审计
数据库
Z***G4791 小时前
【零基础学Mysql】常用函数讲解,提升数据操作效率的利器
数据库·mysql
q***06471 小时前
Spring Boot 从 2.7.x 升级到 3.3注意事项
数据库·hive·spring boot
aml258__1 小时前
MySQL 数据库管理入门:从创建到删除(T1)
数据库·mysql·oracle·初学数据库
悦悦欧呐呐呐呐1 小时前
数据库事务是什么,怎么用的
服务器·数据库·oracle