查看MySQL数据库的SQL语句的执行记录日志

查看MySQL数据库的执行记录日志

SQL语句的执行记录日志

方法1

可以使用processlist查看SQL执行语句,但是有个弊端,就是只能查看正在执行的sql语句,无法查看历史执行的语句。

use information_schema;
show processlist;

或者

select * from information_schema.PROCESSLISTwhere info is not null;

方法2:开启数据库的日志模式

通过日志查看历史执行记录

  • 查看当前配置

show variables like '%log_output%';

show variables like '%general_log%';

  • 开启&关闭日志模式(可选择输出到表或文件中):
sql 复制代码
SET GLOBAL log_output = 'FILE';  SET GLOBAL general_log = 'ON';   //日志开启(日志输出到文件)

SET GLOBAL log_output = 'FILE';  SET GLOBAL general_log = 'OFF';  //日志关闭

或者

sql 复制代码
SET GLOBAL log_output = 'TABLE'; SET GLOBAL general_log = 'ON';   //日志开启(日志输出到表:mysql.general_log)

SET GLOBAL log_output = 'TABLE'; SET GLOBAL general_log = 'OFF';  //日志关闭
  • 查看日志文件中的执行记录:
    #tail -f /var/log/mariadb/mariadb.log

表查询执行记录:

sql 复制代码
SELECT * from mysql.general_log ORDER BY event_time DESC;
  • 清空表

truncate table mysql.general_log; //该表仅支持truncate不支持delete

相关推荐
bobz96519 分钟前
Linux 系统中动态库的作用
后端
华仔啊1 小时前
为什么现代 Node 后端都选 NestJS + TypeScript?这组合真香了
javascript·后端
Joey_Chen1 小时前
【Golang开发】快速入门Go——Go语言中的面向对象编程
后端·go
lookFlying1 小时前
Python 项目 Docker 仓库发布指南
后端
易元1 小时前
模式组合应用-组合模式
后端·设计模式
秋难降1 小时前
从浅克隆到深克隆:原型模式如何解决对象创建的 “老大难”?😘
后端·设计模式·程序员
bobz9651 小时前
安装 nvidia 驱动之前要求关闭 secureBoot 么
后端
程序员的世界你不懂2 小时前
【Flask】测试平台开发实战-第一篇
后端·python·flask
bobz9652 小时前
dracut 是什么?
后端
自由的疯4 小时前
Java RuoYi整合Magic-Api详解
java·后端·架构