zoukankan      html  css  js  c++  java
  • window下Mysql 恢复Delete删除的数据

    转载:https://www.cnblogs.com/q149072205/p/11940591.html

    本机用的Navicat连mysql测试DB又连了正式DB,因为本地与正式要频繁操作所以都打开了很多查询,本来要DELETE删除测试DB的数据,没看清在正式环境执行了。共删除了325条数据,然后在网上找恢复数据的办法,一定要是DELETE删除的,如果用的是drop table删除表是没办法恢复的,具体恢复流程如下

    第一步:先查看binlog功能是否开启

    show variables like '%log_bin%';

    如果为log_bin为ON说明可以恢复,如果为OFF说明没有开启binlog,也没有预先生成回滚SQL,那可能真的无法快速回滚了,GAMEOVER,下面的不用看了(好像可以通过ibd恢复,具体可以参考 https://blog.csdn.net/hanjun0612/article/details/102466509 )。

       第二步:查看数据文件存方路径

    show variables like '%datadir%';

     打开数据库所在路径查看有mysql-bin.****这样的文件,注意DELETE删除的时间,对比mysql-bin文件的修改时间,我的是26号下午18点左右进行的删除数据,所以找mysql-bin.000028这个文件

     

      第三步:找到mysql安装目录

    show variables like "%basedir%";

     CMD命令符进行Mysql安装目录下,找到mysqlbinlog.exe,如果没有说明你安装的是假mysql.

     

      第四步.通过mysqlbinlog 恢复删除的数据日志记录

    mysqlbinlog --base64-output=decode-rows -v --database=DBName --start-datetime="2019-11-26 18:00:00" --stop-datetime="2019-11-26 18:10:00" D:MySQLDatamysql-bin_copy.000028 > mysqllog.sql
    复制代码
    mysqlbinlog 命令的参数说明
    --base64-output=decode-rows //数据转换正常的字符,如果不设置这个参数将显示base64的数据
    --database=DBName  //数据库名(一个mysql数据库比较多,指定方便恢复)
    --start-datetime="2019-11-26 18:00:00"  //恢复起始时间
    --stop-datetime="2019-11-26 18:10:00"  //恢复结束时间
    D:MySQLDatamysql-bin_copy.000028  //为数据恢复的日志文件
    mysqllog.sql    //恢复以后我们需要的文件名
    复制代码

     执行以后如下图:

     打开mysqllog.sql文件,搜索 DELETE 关键字,找到被删除数据,看到这些数据以后总算放心了,如下图:

      第五步:把mysqllog的DELETE转换为Insert语句,这个在liunx下操作方便(有人用python转换也可以),把文件mysqllog.sql复制Liunx下

    cat mysqllog.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' > mysqllogOK.sql

     转换以后打开mysqllogOK.sql文件,因为批量替换前面多个一个分号,去掉以后,把所有生成的Insert语句在navicat下执行即可恢复所有DELETE删除的数据。

     总结:   

    1.不要随便用DELETE,数据做用字段做删除标记,不用使用DELETE删除数据,如果非要删除,删除前一定先备份一下数据

    2.数据库做好定时备份,如果数据库不大,可以一小时备份一次,再大也可以每天备份一次

    3.做事细心,越熟练的事越要细心,本次DELETE导致的加班,就是以为自己对sql熟练就随意操作。

    4.也是最重要的一点,一定要Mysql开启binlog功能

    如果没开启binlog功能的赶紧开启一下吧,mysql开启binLog功能方法(windows),打开my.ini文件,添加如下配置,重启mysql即可开启

    # log-bin
    log-bin=mysql-bin 
    binlog_format = ROW

  • 相关阅读:
    ThinkPHP 3 的CURD管理用户信息 修改和删除
    检测一个字符串是否为一个有效的编码格式字符串
    将Buffer对象结合创建为一个新的Buffer对象
    Buffer.byteLength(字符串,编码方式)计算指定字符串的字节数
    TypeError: Buffer.allocUnsafe is not a function
    多个haproxy 之间跳转
    TypeError: Identifier 'assert' has already been declared
    14.5.7 Storing InnoDB Undo Logs in Separate Tablespaces 存储InnoDB Undo logs 到单独的表空间
    14.5.5 Creating a File-Per-Table Tablespace Outside the Data Directory
    php session 管理
  • 原文地址:https://www.cnblogs.com/hanjun0612/p/11941434.html
Copyright © 2011-2022 走看看