mysql使用binlog恢复数据

今天误删了一个表的部分数据,是用来做权限校验的数据,会影响测试。慌的一批,最后通过binlog日志找回了删除的数据,上教程

  1. 指令定位binlog文件位置
# 查看binlog是否开启。必须开启
show variables like 'log_%';
# 查看当前正在使用的binlog文件
show master status;
# 查看binlog文件所在位置
show variables like '%datadir%';

# 上述两者的值组合起来即是binlog文件的位置

在这里插入图片描述

  1. 利用navicat的日志工具确定大概的删除数据的时间。
    我是用的navicat进行删除的哈,记住大概时间区间即可
    在这里插入图片描述

  2. 进入服务器目录使用mysqlbinlog指令进行查看删除的数据内容
    注意:1.切换到mysql的bin目录下直接使用mysqlbinlog指令
    2.使用全路径方式使用mysqlbinlog指令

#mysqlbinlog指令:指定具体的数据库、指定binlog文件、指定开始以及结束时间即可。
/data/mysql/bin/mysqlbinlog --no-defaults --database=exam_business2 --start-datetime="2021-12-13 11:00:00" --stop-datetime="2021-12-13 11:20:00"  --base64-output=DECODE-ROWS -v /data/mysql/data/master-bin.000013  >/路径/文件名.txt

该命令会将查询到的日志文件存储到txt文件中。筛选处理进行数据恢复。
4. 大概样式
在这里插入图片描述

END

过程就是将指定的时间区间的操作记录存储到txt,对数据进行筛选 后执行插入操作在恢复!

前提是开启了该设置才可以,祝各位好运!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值