前面的一些章节我们对mysqldump常用命令进行了讲解 这个专题的内容为mysqlbinlog命令的详解 mysqlbinlog是mySQL中用来处理binlog的工具 ## 1. MySQL二进制日志介绍 服务器的binlog包含一些event 这些event描述了数据库内容的状态,包含了数据修改,服务器重启等,以二进制的格式写入日志文件 这里和redo log相似,不过redo是存储引擎层面的,而binlog是数据库层面的 即一个MySQL不一定有redo日志 但一定有binlog(开启) 可以使用mysqlbinlog工具来将二进制转换为文本格式 同理我们也可以使用mysqlbinlog来处理relay log ## 2. 实验环境准备 此次实验的环境如下 - MySQL 5.7.25 - Redhat 6.10 - binlog模式采用row模式 这里我们构造一些DML语句来演示mysqlbinlog如何工作的 ### 2.1 重置binlog 我们使用如下命令重置binlog,方便我们观察 ``` SQL>reset master; SQL>show master status; ``` [image:551 size:orig] ### 2.2 建立表 ``` create database test; use test ``` ``` CREATE TABLE `innodb_table` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(20) NOT NULL, `age` tinyint(3) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=innodb DEFAULT CHARSET=utf8 AUTO_INCREMENT=1; ``` ### 2.3 单条插入语句 ``` INSERT INTO `innodb_table`(`name`,`age`) VALUES( 'insert1', CEIL(RAND() * 110) ); INSERT INTO `innodb_table`(`name`,`age`) VALUES( 'insert2', CEIL(RAND() * 110) ); INSERT INTO `innodb_table`(`name`,`age`) VALUES( 'insert3', CEIL(RAND() * 110) ); ``` ### 2.4 单条更新语句 ``` update innodb_table set name='update1' where id=1; update innodb_table set name='update2' where id=2; update innodb_table set name='update3' where id=3; ``` ### 2.5 事务多条语句 ``` START TRANSACTION; INSERT INTO `innodb_table`(`name`,`age`) VALUES( 'trans_insert1', CEIL(RAND() * 110) ); INSERT INTO `innodb_table`(`name`,`age`) VALUES( 'trans_insert2',CEIL(RAND() * 110) ); INSERT INTO `innodb_table`(`name`,`age`) VALUES( 'trans_insert3', CEIL(RAND() * 110) ); update innodb_table set name='commit_update1' where id=1; update innodb_table set name='commit_update2' where id=2; update innodb_table set name='commit_update3' where id=3; COMMIT; ``` ### 2.6 事务回滚语句 ``` START TRANSACTION; INSERT INTO `innodb_table`(`name`,`age`) VALUES( 'rooback_insert1', CEIL(RAND() * 110) ); update innodb_table set name='rollback_update1' where id=1; ROLLBACK; ``` ### 2.6 event更新 event 更新数据请移步下面链接 [mysqldump命令详解 Part 1](http://www.zhaibibei.cn/mysql/tutorial/tutorial2) ### 2.7 procedure更新 procedure更新移步下面链接 [MySQL测试数据的构造](http://www.zhaibibei.cn/mysql/tutorial/tutorial1/) 好了,环境准备已经好了,大家按照上面的步骤执行 下届开始讲解mysqlbinlog的命令