打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
mysqlbinlog命令详解 Part 1-实验环境准备
userphoto

2022.05.30 江苏

关注

往期专题请查看www.zhaibibei.cn
这是一个坚持Oracle,Python,MySQL原创内容的公众号

前面都一些章节我们对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;

2.2 建立表

create database test;
use test
CREATE TABLE `innodb_table` (
        `id` int(11NOT NULL AUTO_INCREMENT,
        `name` varchar(20NOT NULL,
        `age` tinyint(3NOT 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 更新数据请移步下面链接

[MySQL学习笔记]2. mysqldump命令详解 Part 1

2.7 procedure更新

procedure更新移步下面链接

[MySQL学习笔记]1. MySQL测试数据的构造

好了,环境准备已经好了,大家按照上面的步骤执行

下届开始讲解mysqlbinlog的命令

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
MySQL的这个bug,坑了多少人?
计划之每日分析binlog!
深入分析mysql日志教程
24.MySQL是怎么保证主备一致的undefined
MySQL日志
set global sql_slave_skip_counter
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服