MySQL根据binlog恢复数据

  1. 查询MySQL当前使用的binlog文件
#查看是否开启binlog
show variables like 'log_%';
#查看所有binlog日志列表 
show master logs;
#查询当前使用的binlog文件
show master status;
  1. 根据删除语句大概执行时间确定执行点
mysqlbinlog -vv  --start-datetime='2022-11-27 18:30:00' --stop-datetime='2022-11-27 18:35:00' /mysql-logs/binlogs/mysql-bin.000671 > binlog.txt

输出大概是这种格式:

BEGIN
/*!*/;
# at 11742  注意这个是deleted的开始节点
#221130 21:22:52 server id 1  end_log_pos 11869 CRC32 0xd23d8935 	Table_map: `test`.`nucleic_acid_record_info_copy1` mapped to number 110
# at 11869
#221130 21:22:52 server id 1  end_log_pos 19010 CRC32 0x407cfd2f 	Delete_rows: table id 110 flags: STMT_END_F

BINLOG '
LFmHYxMBAAAAfwAAAF0uAAAAAG4AAAAAAAEABHRlc3QAHm51Y2xlaWNfYWNpZF9yZWNvcmRfaW5m
b19jb3B5MQASCA8SEg8PDw8PEhL+/AEPDw8PGwABAAAACAAIAAiQAZABAAD+BAIAAvwD/AP8A/73
AwEBAAID/P8ANYk90g==
LFmHYyABAAAA5RsAAEJKAAAAAG4AAAAAAAEAAgAS5lcAKi4BAAAAAACZrkowUQ0A6Zi05oCn
77yILe+8iQEwAA4AMDE3MTEwNjIyMDE1NDABAC8BAC/mVwArLgEAAAAAAJmuSjBRDQDpmLTmgKfv

NzExMDE0NDYxMjUyL/18QA==
'/*!*/;
### DELETE FROM `test`.`nucleic_acid_record_info_copy1`
### WHERE
###   @1=77354 /* LONGINT meta=0 nullable=0 is_null=0 */
###   @2=NULL /* VARSTRING(256) meta=256 nullable=1 is_null=1 */
###   @3=NULL /* DATETIME(0) meta=0 nullable=1 is_null=1 */
###   @4='2022-11-05 03:01:17' /* DATETIME(0) meta=0 nullable=1 is_null=0 */
###   @5='阴性(-)' /* VARSTRING(2048) meta=2048 nullable=1 is_null=0 */
###   @6=NULL /* VARSTRING(2048) meta=2048 nullable=1 is_null=1 */
###   @7=NULL /* VARSTRING(2048) meta=2048 nullable=1 is_null=1 */
###   @8=NULL /* VARSTRING(400) meta=400 nullable=1 is_null=1 */
###   @9=NULL /* VARSTRING(400) meta=400 nullable=1 is_null=1 */
###   @10=NULL /* DATETIME(0) meta=0 nullable=1 is_null=1 */
###   @11=NULL /* DATETIME(0) meta=0 nullable=1 is_null=1 */
###   @12='0' /* STRING(4) meta=65028 nullable=0 is_null=0 */
###   @13=NULL /* BLOB/TEXT meta=2 nullable=1 is_null=1 */
###   @14=0 /* TINYINT meta=0 nullable=1 is_null=0 */
###   @15=NULL /* VARSTRING(512) meta=512 nullable=1 is_null=1 */
###   @16='01711062201540' /* VARSTRING(1020) meta=1020 nullable=1 is_null=0 */
###   @17='/' /* VARSTRING(1020) meta=1020 nullable=1 is_null=0 */
###   @18='/' /* VARSTRING(1020) meta=1020 nullable=1 is_null=0 */
# at 19010  注意这个是deleted的结束节点
#221130 21:22:52 server id 1  end_log_pos 19041 CRC32 0xf1af8408 	Xid = 289
COMMIT/*!*/;
SET @@SESSION.GTID_NEXT= 'AUTOMATIC' /* added by mysqlbinlog */ /*!*/;
DELIMITER ;
# End of log file
/*!50003 SET COMPLETION_TYPE=@OLD_COMPLETION_TYPE*/;
/*!50530 SET @@SESSION.PSEUDO_SLAVE_MODE=0*/;
  1. 根据deleted执行的开始节点和结束节点将binlog导出
mysqlbinlog -vv --start-position=159953715 --base64-output=decode-rows --stop-position=162292672 /mysql-logs/binlogs/mysql-bin.000671 |grep ^"###" > logs/binlog.data
  1. 执行命令语句将binlog文件转为insert语句
cat logs/binlog.data | sed -n '/###/p' | sed 's/### //g;s/\/\*.*/,/g;s/DELETE FROM/INSERT INTO/g;s/WHERE/SELECT/g;' |sed -r 's/(@6.*),/\1;/g' | sed 's/@[1-9]=//g' | sed 's/@[1-9][0-9]=//g' >/data/insert.sql
  1. 最终的执行语句格式还得手动修改,修改完后直接mysql执行脚本即可
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL的二进制日志binlog)记录了对数据库的所有更改操作,包括增删改等操作。如果你误删了某些数据,可以使用binlog来进行恢复。 以下是使用binlog恢复数据的步骤: 1. 确认binlog是否开启,在MySQL配置文件中确认是否有以下配置: ``` [mysqld] log-bin=mysql-bin ``` 如果没有,则需要在配置文件中添加上述配置,并重新启动MySQL服务。 2. 查看binlog日志文件列表 可以使用以下命令查看binlog日志文件列表: ``` mysqlbinlog --no-defaults --base64-output=DECODE-ROWS -v --start-datetime="2022-01-01 00:00:00" --stop-datetime="2022-01-01 23:59:59" mysql-bin.000001 > /tmp/mysql_binlog.sql ``` 上述命令将把2022年1月1日这一天的binlog日志文件转换成文本格式,并保存到/tmp/mysql_binlog.sql文件中。 3. 找到误删的SQL语句 在/binlog.sql文件中查找误删的SQL语句,可以使用grep命令查找。 例如,查找包含“DELETE FROM users WHERE id=100”的SQL语句: ``` grep "DELETE FROM users WHERE id=100" /tmp/mysql_binlog.sql ``` 4. 恢复数据 找到误删的SQL语句后,可以使用mysql客户端连接到数据库,并执行该语句来恢复数据。 例如,执行以下命令来恢复数据: ``` mysql -u root -p mysql> use mydatabase; mysql> DELETE FROM users WHERE id=100; ``` 以上就是使用binlog恢复数据的步骤。需要注意的是,在执行恢复操作前,最好先备份一下数据库,以防止误操作导致数据丢失。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值