本文摘自PHP中文网,作者青灯夜游,侵删。
mysql对数据的更新操作记录在通用查询日志和二进制日志中。通用查询日志用来记录用户的所有操作,包括启动和关闭 MySQL 服务、更新语句和查询语句等;二进制日志会以二进制的形式记录数据库的各种操作,但不记录查询语句。

(推荐教程:mysql视频教程)
日志是数据库的重要组成部分,主要用来记录数据库的运行情况、日常操作和错误信息。
MySQL通用查询日志(General Query Log)
通用查询日志(General Query Log)用来记录用户的所有操作,包括启动和关闭 MySQL 服务、更新语句和查询语句等。
默认情况下,通用查询日志功能是关闭的。可以通过以下命令查看通用查询日志是否开启,命令如下:
1 2 3 4 5 6 7 8 | mysql> SHOW VARIABLES LIKE '%general%' ;
+
| Variable_name | Value |
+
| general_log | OFF |
| general_log_file | C:\ProgramData\MySQL\MySQL Server 5.7\Data\LAPTOP-UHQ6V8KP.log |
+
2 rows in set , 1 warning (0.01 sec)
|
从结果可以看出,通用查询日志是关闭的,general_log_file 变量指定了通用查询日志文件所在的位置。
启动和设置通用查询日志
在 MySQL 中,可以通过在 MySQL 配置文件添加 log 选项来开启通用查询日志,格式如下:
其中,dir 参数指定通用查询日志的存储路径;filename 参数指定日志的文件名。如果不指定存储路径,通用查询日志将默认存储到 MySQL 数据库的数据文件夹下。如果不指定文件名,默认文件名为 hostname.log,其中 hostname 表示主机名。
查看通用查询日志
如果希望了解用户最近的操作,可以查看通用查询日志。通用查询日志以文本文件的形式存储,可以使用普通文本文件查看该类型日志内容。
例 1
首先我们查看通用查询日志功能是否是开启状态,然后查询 tb_student 表的记录,SQL 命令和执行过程如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | mysql> SHOW VARIABLES LIKE '%general%' ;
+
| Variable_name | Value |
+
| general_log | ON |
| general_log_file | C:\ProgramData\MySQL\MySQL Server 5.7\Data\LAPTOP-UHQ6V8KP.log |
+
2 rows in set , 1 warning (0.02 sec)
mysql> use test;
Database changed
mysql> SELECT * FROM tb_student;
+
| id | name |
+
| 1 | Java |
| 2 | MySQL |
| 3 | Python |
+
|
3 rows in set (0.06 sec)
执行成功后,打开通用查询日志,这里日志名称为 LAPTOP-UHQ6V8KP.log,下面是通用查询日志中的部分内容。
1 2 3 4 5 6 7 8 9 10 | C:\Program Files\MySQL\MySQL Server 5.7\bin\mysqld.exe, Version: 5.7.29-log (MySQL Community Server (GPL)). started with:
TCP Port: 3306, Named Pipe: MySQL
Time Id Command Argument
2020-05-29T06:43:44.382878Z 7 Quit
2020-05-29T06:44:10.001382Z 8 Connect root@localhost on using SSL/TLS
2020-05-29T06:44:10.007532Z 8 Query select @@version_comment limit 1
2020-05-29T06:44:11.748179Z 8 Query SHOW VARIABLES LIKE '%general%'
2020-05-29T06:44:25.487472Z 8 Query SELECT DATABASE()
2020-05-29T06:44:25.487748Z 8 Init DB test
2020-05-29T06:44:35.390523Z 8 Query SELECT * FROM tb_student
|
可以看出,该日志非常清晰地记录了客户端的所有行为。
阅读剩余部分
相关阅读 >>
mysql表被锁了怎么办?
mysql中curdate()函数的代码案例
如何使用mysql中“<=>”操作符
mysql创建存储过程并循环添加记录方法详解
mysql数据库面试必备之三大log介绍
分享一些mysql数据库的优化技巧
mysql数据表操作实例详解
mysql8.0.23 msi安装超详细教程
mysql怎么删除触发器
window环境配置mysql 5.7.21 windowx64.zip免安装版教程详解
更多相关阅读请进入《mysql》频道 >>
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » mysql对数据的更新操作记录在哪个日志中?