mysql对数据的更新操作记录在哪个日志中?


本文摘自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 选项来开启通用查询日志,格式如下:

1

2

[mysqld]

log=dir/filename

其中,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个别文字乱码的问题

mysql工具如何导出表?

大揭秘!mysql数据库之索引

python操作mysql数据库的简单步骤分享

mysql索引详解(总结)

navicat 8 for mysql怎么建库

mysql子查询简单介绍

sql server和mysql的区别是什么

mysql与redis实现二级缓存的方法介绍(代码示例)

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...