查看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

相关推荐
copyer_xyf31 分钟前
Python 内存分析:从栈和堆理解对象引用
前端·后端·python
金銀銅鐵1 小时前
用 Tkinter 实现一个简单的罗马数字转化工具
后端·python
RemainderTime2 小时前
Spring Boot脚手架集成 Spring Security实现生产级RBAC鉴权
spring boot·后端·spring
用户2330713074792 小时前
对象的一生(上)
后端
爱勇宝2 小时前
如何评估 AI 大模型的商业价值?
前端·后端·程序员
AskHarries2 小时前
Landing Page 验证法
后端
卷无止境4 小时前
C# 与 .NET 中的委托:把方法装进变量里
后端
绛洞花主敏明4 小时前
Go操作xorm中间表多对多关联实战
开发语言·后端·golang
长栎4 小时前
手写一个表达式计算器,你就理解解释器模式了
后端
长栎4 小时前
foreach 语法糖背后,迭代器模式做了多少脏活
后端