前面的一些章节我们对mysqldump常用命令进行了讲解
这个专题的内容为mysqlbinlog命令的详解
mysqlbinlog是mySQL中用来处理binlog的工具
服务器的binlog包含一些event
这些event描述了数据库内容的状态,包含了数据修改,服务器重启等,以二进制的格式写入日志文件
这里和redo log相似,不过redo是存储引擎层面的,而binlog是数据库层面的
即一个MySQL不一定有redo日志 但一定有binlog(开启)
可以使用mysqlbinlog工具来将二进制转换为文本格式
同理我们也可以使用mysqlbinlog来处理relay log
此次实验的环境如下
这里我们构造一些DML语句来演示mysqlbinlog如何工作的
我们使用如下命令重置binlog,方便我们观察
SQL>reset master;
SQL>show master status;
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;
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) );
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;
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;
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;
event 更新数据请移步下面链接
procedure更新移步下面链接
好了,环境准备已经好了,大家按照上面的步骤执行
下届开始讲解mysqlbinlog的命令