mysql对数据的更新操纵记载在哪个日志中?
mysql对数据的更新操纵记载在通用查询日志和二进制日志中。通用查询日志用来记载会员的所有操纵,包含启动和关闭 MySQL 办事、更新语句和查询语句等;二进制日志会以二进制的情势记载数据库的各种操纵,但不记载查询语句。
(举荐教程:mysql视频教程)
日志是数据库的重要组成局部,主要用来记载数据库的运转状况、日常操纵和差错信息。
MySQL通用查询日志(General Query Log)
通用查询日志(General Query Log)用来记载会员的所有操纵,包含启动和关闭 MySQL 办事、更新语句和查询语句等。
默许状况下,通用查询日志功能是关闭的。可以通过下列下令查看通用查询日志可否开启,下令如下:
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 选项来开启通用查询日志,格局如下:
[mysqld] log=dir/filename
其中,dir 参数指定通用查询日志的存储途径;filename 参数指定日志的文件名。要是不指定存储途径,通用查询日志将默许存储到 MySQL 数据库的数据文件夹下。要是不指定文件名,默许文件名为 hostname.log,其中 hostname 表示主机名。
查看通用查询日志
要是但愿理解会员比来的操纵,可以查看通用查询日志。通用查询日志以文本文件的情势存储,可以运用普通文本文件查看该类型日志内容。
例 1
第一我们查看通用查询日志功能可否是开启状态,然后查询 tb_student 表的记载,SQL 下令和施行历程如下:
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,下面是通用查询日志中的局部内容。
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二进制日志(Binary Log)
二进制日志(Binary Log)也可叫作变动日志(Update Log),是 MySQL 中非常重要的日志。主要用于记载数据库的变化状况,即 SQL 语句的 DDL 和 DML 语句,不包括数据记载查询操纵。
要是 MySQL 数据库不测休止,可以通过二进制日志文件来查看会员施行了哪些操纵,对数据库办事器文件做了哪些修改,然后依据二进制日志文件中的记载来恢复数据库办事器。
默许状况下,二进制日志功能是关闭的。可以通过下列下令查看二进制日志可否开启,下令如下:
mysql> SHOW VARIABLES LIKE 'log_bin'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | log_bin | OFF | +---------------+-------+ 1 row in set, 1 warning (0.02 sec)
从效果可以看出,二进制日志是关闭的。
启动和设定二进制日志
在 MySQL 中,可以通过在配置文件中增加 log-bin 选项来开启二进制日志,格局如下:
[mysqld] log-bin=dir/[filename]
其中,dir 参数指定二进制文件的存储途径;filename 参数指定二进制文件的文件名,其情势为 filename.number,number 的情势为 000001、000002 等。
每次重新启动 MySQL 办事后,都会生成一个新的二进制日志文件,这些日志文件的文件名中 filename 局部不会转变,number 会一直递增。
要是没有 dir 和 filename 参数,二进制日志将默许存储在数据库的数据名目下,默许的文件名为 hostname-bin.number,其中 hostname 表示主机名。
下面在 my.ini 文件的 [mysqld] 组中增加下列语句:
log-bin
重新启动 MySQL 办事器后,可以在 MySQL 数据库的数据名目下看到 LAPTOP-UHQ6V8KP-bin.000001 这个文件,同时还生成了 LAPTOP-UHQ6V8KP-bin.index 文件。此处,MySQL 办事器的主机名为 LAPTOP-UHQ6V8KP。
还可以在 my.ini 文件的 [mysqld] 组中进行如下修改。语句如下:
log-bin=C:log\mylog
重新启动 MySQL 办事后,可以在 C:log 文件夹下看到 mylog.000001 文件和 mylog.index 文件。
查看二进制日志
1. 查看二进制日志文件列表
可以运用如下下令查看 MySQL 中是什么二进制日志文件:
mysql> SHOW binary logs; +----------------------------+-----------+ | Log_name | File_size | +----------------------------+-----------+ | LAPTOP-UHQ6V8KP-bin.000001 | 177 | | LAPTOP-UHQ6V8KP-bin.000002 | 154 | +----------------------------+-----------+ 2 rows in set (0.00 sec)
2. 查看目前正在写入的二进制日志文件
可以运用下列下令查看目前 MySQL 中正在写入的二进制日志文件。
mysql> SHOW master status; +----------------------------+----------+--------------+------------------+-------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set | +----------------------------+----------+--------------+------------------+-------------------+ | LAPTOP-UHQ6V8KP-bin.000002 | 154 | | | | +----------------------------+----------+--------------+------------------+-------------------+ 1 row in set (0.00 sec)
3. 查看二进制日志文件内容
二进制日志运用二进制格局存储,不克不及直接打开查看。要是需要查看二进制日志,必需运用 mysqlbinlog 下令。
mysqlbinlog 下令的语法情势如下:
mysqlbinlog filename.number
mysqlbinlog 下令只在目前文件夹下查寻指定的二进制日志,因而需要在二进制日志所在的名目下运转该下令,不然将会寻不到指定的二进制日志文件。
例 1
下面运用 mysqlbinlog 下令,来查看 C:\log 名目下的 mylog.000001 文件,代码施行如下:
C:\Users\11645>cd C:\log C:\log>mysqlbinlog mylog.000001 /*!50530 SET @@SESSION.PSEUDO_SLAVE_MODE=1*/; /*!50003 SET @OLD_COMPLETION_TYPE=@@COMPLETION_TYPE,COMPLETION_TYPE=0*/; DELIMITER /*!*/; # at 4 #200527 9:33:37 server id 1 end_log_pos 123 CRC32 0x69738cfd Start: binlog v 4, server v 5.7.29-log created 200527 9:33:37 at startup ......
因为日志内容较长,这里只展现了 mylog 中的局部内容。
运用 mysqlbinlog 下令时,可以指定二进制文件的存储途径。这样可以确保 mysqlbinlog 下令可以寻到二进制文件。上面例子中的下令可以变为如下情势:
mysqlbinlog C:\log\mylog.000001
这样,mysqlbinlog 下令就会到 C:\log 名目下去查寻 mylog.000001 文件。要是不指定途径,mysqlbinlog 下令将在目前名目下查寻 mylog.000001 文件。
除了 filename.number 文件,MySQL 还会生成一个名为 filename.index 的文件,这个文件存储着所有二进制日志文件的列表,可以用记事本打开该文件。
小技巧:现实工作中,二进制日志文件与数据库的数据文件不放在统一块硬盘上,这样即便数据文件所在的硬盘被毁坏,也可以运用另一块硬盘上的二进制日志来恢复数据库文件。两块硬盘同时坏了的可能性要小得多,这样可以保障数据库中数据的平安。
更多编程相干见识,请拜访:编程入门!!
以上就是mysql对数据的更新操纵记载在哪个日志中?的细致内容,更多请关注 百分百源码网 其它相干文章!