mysql二进制日志导入_mysql使用二进制日志恢复数据

一、恢复到某个二进制文件

1.开启二进制日志

在mysqld的配置节点下添加如下配置

log-bin="E:/Mysql57BinLog/binlog"(windows下的路径,linux下自行修改路径)

expire_logs_days=10

max_binlog_size=100M

2.重启mysql服务

使用命令show VARIABLES like '%log_bin%';查看

87a2e7be5abd3c192407131abf76f425.png

3.创建库和表

create database mytest;

use mytest;

create table t(a int PRIMARY key)ENGINE = INNODB DEFAULT CHARSET=utf8;

flush logs;

flush logs,刷新二进制日志后会多出来一个二进制日志

800271cf5bfdf8677a7292db65c9dc26.png

使用命令查看二进制日志内容

ee732041a17c4c420cc8b9b8ae58e6fa.png

默认会读取配置文件,检测到no--beep会报错。

推荐使用命令:mysqlbinlog --no-defaults E:\Mysql57BinLog\binlog.000001

02affd6ea94173ec87afabd934d52061.png

4.插入数据

use mytest;

insert into t select 1 union all select 2 union all select 3;

flush logs;

b75a7233efdd2a9937fef83cbd887943.png

5.删除数据库

drop database mytest;

flush logs;

ff16f6c483672e5e782d5e1e1ccb6c82.png

6.恢复数据

mysqlbinlog --no-defaults E:\Mysql57BinLog\binlog.000001 E:\Mysql57BinLog\binlog.000002 E:\Mysql57BinLog\binlog.000003 | mysql -u root -p

47cae44e10c49037f648bb03fd7d8aa6.png

1fc37680b77ccabd90c21ce4cbf9e7b0.png

数据已还原。

-----------------------------------华丽的分割线--------------------------------------------------------------

二、恢复到某一时间点的数据

create table t2(a int PRIMARY key)ENGINE=INNODB default CHARSET=utf8;

insert into t2 values(1),(2),(3),(4),(5);

>mysqlbinlog --no-defaults E:\Mysql57BinLog\binlog.000006

ebdc6fe585d11bab2ca626e345af8424.png

删除数据

delete from t2 where a < 4;

4b695b37cd166eaff7b9fd441b85e022.png

恢复数据

8898c875c46f45d283e2e8d4898a2bfa.png

drop database mytest;

删除库mytest,回到最原始的地方

mysqlbinlog --no-defaults --start-position="4" --stop-position="1285" E:\Mysql57BinLog\binlog.000006  | mysql -u root -p

36aa262d668686b1fbba2e434335b17c.png

a9116a00130c1bfcb76d48b74ddf7b97.png

数据恢复成功。

欢迎大家拍砖~~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值