mysql通过binlog日志恢复误删数据

1、先查看binlog功能是否开启

bash 复制代码
show variables like '%log_bin%';


log_bin为ON说明可以使用binlog恢复,如果为OFF说明没有开启binlog。

2、删除部分数据做测试


3、查找binlog文件位置

bash 复制代码
show variables like '%datadir%';
bash 复制代码
cd /var/lib/mysql

ls -l

删除数据时间是在文件154与153之间,所以删除操作应在154文件中

4、解析日志

mysqlbinlog命令解析日志存入新文件

bash 复制代码
mysqlbinlog --base64-output=decode-rows -v --database=DBName --start-datetime="2023-08-21 16:50:00" --stop-datetime="2023-08-21 17:05:00" /var/lib/mysql/mysql-bin.000154 > mysqllog-154.sql


mysqlbinlog 命令的参数说明

bash 复制代码
--base64-output=decode-rows //数据转换正常的字符,如果不设置这个参数将显示base64的数据
--database=DBName //数据库名(一个mysql数据库比较多,指定方便恢复)
--start-datetime=恢复起始时间
--stop-datetime=恢复结束时间
/var/lib/mysql/mysql-bin_copy.000154 //为数据恢复的日志文件
mysqllog-154.sql//恢复以后我们需要的文件名

sz命令下载文件到本地

在文件中找到了detele语句

5、语句转换

把mysqllog-154.sql中的DELETE转换为Insert语句,使用以下命令:

bash 复制代码
cat mysqllog-154.sql | sed -n '/###/p' | sed 's/### //g;s/\/\*.*/,/g;s/DELETE FROM/;INSERT INTO/g;s/WHERE/SELECT/g;' |sed -r 's/(@17.*),/\1;/g' | sed 's/@1=//g'| sed 's/@[1-9]=/,/g' | sed 's/@[1-9][0-9]=/,/g' > mysqlOK.sql


打开mysqlOK.sql文件


6、数据恢复

执行sql文件,即可将删除数据恢复:

相关推荐
success_a1 小时前
大故障:阿里云核心域名爆炸了
数据库·阿里云·云计算
@小红花4 小时前
MySQL数据库从0到1
数据库·mysql·oracle
[听得时光枕水眠]4 小时前
MySQL基础(三)DQL(Data Query Language,数据查询语言)
数据库·mysql·oracle
我科绝伦(Huanhuan Zhou)4 小时前
深入解析Oracle SQL调优健康检查工具(SQLHC):从原理到实战优化
数据库·sql·oracle
一只叫煤球的猫8 小时前
MySQL 8.0 SQL优化黑科技,面试官都不一定知道!
后端·sql·mysql
寒山李白8 小时前
MySQL安装与配置详细讲解
数据库·mysql·配置安装
文牧之8 小时前
PostgreSQL 的扩展pg_freespacemap
运维·数据库·postgresql
deriva9 小时前
某水表量每15分钟一报,然后某天示数清0了,重新报示值了 ,如何写sql 计算每日水量
数据库·sql
Leo.yuan10 小时前
数据库同步是什么意思?数据库架构有哪些?
大数据·数据库·oracle·数据分析·数据库架构