前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mysqlbinlog命令详解 Part 1-实验环境准备

mysqlbinlog命令详解 Part 1-实验环境准备

作者头像
bsbforever
发布2020-08-19 16:46:47
3310
发布2020-08-19 16:46:47
举报
文章被收录于专栏:时悦的学习笔记

前面的一些章节我们对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,方便我们观察

代码语言:javascript
复制
SQL>reset master;

SQL>show master status;
1_2.png
1_2.png

2.2 建立表

代码语言:javascript
复制
create database test;
use test
代码语言:javascript
复制
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 单条插入语句

代码语言:javascript
复制
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 单条更新语句

代码语言:javascript
复制
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 事务多条语句

代码语言:javascript
复制
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 事务回滚语句

代码语言:javascript
复制
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

2.7 procedure更新

procedure更新移步下面链接

MySQL测试数据的构造

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

下届开始讲解mysqlbinlog的命令

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-07-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 宅必备 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. MySQL二进制日志介绍
  • 2. 实验环境准备
    • 2.1 重置binlog
      • 2.2 建立表
        • 2.3 单条插入语句
          • 2.4 单条更新语句
            • 2.5 事务多条语句
              • 2.6 事务回滚语句
                • 2.6 event更新
                  • 2.7 procedure更新
                  相关产品与服务
                  云数据库 SQL Server
                  腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
                  领券
                  问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档