百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> mysql对数据的更新操纵记载在哪个日志中?
分享文章到:

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

发布时间:12/01 来源:未知 浏览: 关键词:
mysql对数据的更新操纵记载在通用查询日志和二进制日志中。通用查询日志用来记载会员的所有操纵,包含启动和关闭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对数据的更新操纵记载在哪个日志中?的细致内容,更多请关注 百分百源码网 其它相干文章!

打赏

打赏

取消

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

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

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

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有151人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板