使用binlog,实现MySQL数据恢复

mysql的binlog日志,用于记录数据库的增、删、改等修改操作,默认处于关闭状态。使用binlog实现数据恢复的条件为

1、binlog日志功能已开启

2、若binlog在数据库创建一段时候后开启,则实现恢复数据需要基于binlog开启之后某一时刻的数据备份

3、binlog工作在Statement level(默认)模式,隔离级别为 repeatable read 时,采用乐观锁并发插入数据,可能发生死锁

  乐观锁: insert into A

      select a, b, c from dual

        where exists(select 1 from dual where '...' = (select max(...) from A)) 

  错误信息:Deadlock found when trying to get lock; try restarting transaction

  隔离级别为read committed 时,依然报错:impossible to write to binary log since BINLOG_FORMAT = STATEMENT and at least one table uses a storage engine limited to row-based logging

  即便查询和插入的数据范围不重合(如不同客户同时插入数据),依然如此;binlog工作在Mixed模式下不存在该情况,具体原因待研究

binlog的使用及数据恢复过程,可参考一下分享:

Mysql误删表中数据与误删表的恢复方法

MySQL Binlog详解

活用mysql的binlog进行数据恢复

原文地址:https://www.cnblogs.com/MattCheng/p/8533438.html