mysql Bing 恢复数据_MySQL log_bing恢复delete / update /drop 数据

首先开启MySQL的log_bin设置,修改mysql配置文件

#vim /etc/my.cnf

在[mysqld]下检查是否有 log-bin=mysql-bin  设置,没有的话加上这条设置

重启mysql

测试是否启用log-bin,在数据库新建一个数据表,然后到mysql的文件目录下寻找是否存在mysql-bin.00000X文件

如果有说明配置生效

下面开始举例说明

新建testtable表,添加id,name两个字段,插入3条信息,然后使用delete from testtable;删除表内容

回到控制台:

#mysqlbinlog mysql-bin.00001 > 1.sql

生成1.sql文件,这个文件就是记录了我们的数据库操作信息,查看sql文件

#vim 1.sql

里面的内容为:

# at 21302

# at 21334

#180326 16:11:27 server id 1 end_log_pos 21334 CRC32 0xc4b3a95b Intvar

SET INSERT_ID=1558/*!*/;

#180326 16:11:27 server id 1 end_log_pos 21509 CRC32 0xd8e0b556 Query thread_id=21 exec_time=0 error_code=0

SET TIMESTAMP=1522051887/*!*/;

insert into XSJL (SKTNO,JYH,SP_ID,HTH,XSJE,ZKJE,XSSL) values ('1238',218440,818937,1290300,704,176,1)

at指在说明位置处

180326 16:11:27  是时间记录

insert into xsjl()...   记录的是你执行的sql语句,

我们一般都采用时间标记法来恢复数据

找到你想回滚的时间记录值,进行回滚就可以了

#mysqlbinlog mysql-bin.000001 --start-datetime='2018-03-26 15:39:50' --stop-datetime='2018-03-26 15:40:39' | mysql -uroot -p

--start-datetime  开始回滚的日期标记起始位置  --stop-datetime 反义

到这里就结束了。

这是简单的回滚,因为我们的log-bin 记录的是数据库所有表的操作记录,所以数据表的更新信息交错复杂,我们实际生产中

如果想恢复一个被delete的table是相当麻烦的,因为我们在得到log-bin的sql文件后,要通过一系列方法把,这个表的操作记录

筛选出来,才能进行恢复,不然的话我们直接恢复的就会造成其他表的数据错乱问题。

这里给一点建议,最好采用我博客里说的另外一种方法进行数据库备份

https://mp.csdn.net/postedit/79695669

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值