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:\MySQL\Data\mysql-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:\MySQL\Data\mysql-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
相关文章
- mysql增删改
- 【知识库】-数据库_MySQL 的七种 join
- Mysql授权允许远程访问解决Navicat for MySQL连接mysql提示客户端不支持服务器请求的身份验证协议;考虑升级MySQL客户端
- 【Mysql 学习】mysqld_safe:MySQL服务器启动脚本
- 检测MYSQL不同步发邮件通知的脚本
- mysql启动时报错:Starting MySQL... ERROR! The server quit without updating PID file (/opt/mysql/data/mysql.pid) 的解决方法
- MYSQL错误解决:ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)
- 数据库基础之Mysql(3)mysql删除历史binlog
- 解决python写入mysql中datetime类型遇到的问题
- MySQL--执行mysql脚本及其脚本编写
- mysql 必知必会整理—数据插入和更新还有删除[十]
- Warning: mysql_fetch_array(): supplied argument is not a valid MySQL result
- Mysql中SQL语句不使用索引的情况
- Mysql 如果有多个可选条件怎么加索引_MySQL|mysql-索引
- 【高可用MySQL解决方案】centos7配置mysql主从复制
- 〖Python 数据库开发实战 - MySQL篇㉖〗- 数据删除操作 - DELETE语句
- mysql执行update语句受影响行数是0
- Mysql InnoDB 数据更新/删除导致锁表
- 【数据库技术】MySQL索引背后的数据结构及算法原理
- 全网详细解决Client does not support authentication protocol requested by server;consider upgrading Mysql c
- Mysql之binlog日志说明及利用binlog日志恢复数据操作记录
- Mysql 根据一个表数据更新另外一个表
- paip.将数据导入到在英语语音数据库mysql道路解决空原则问题
- MySQL删除表数据
- Mysql load data infile 导入数据出现:Data truncated for column
- MySQL--全文索引作用、原理及使用注意
- 10_Influxdb+Grafana监控Mysql
- 字段的某记录相同,但是时间不同,找到MySQL里面最新的数据
- 提高MySQL数据可靠性的必备技能:基于MySQL8实现主从同步
- 如何在MySQL 8中实现数据迁移?这里有一个简单易用的方案
- docker运行mysql并数据持久化
- MySQL 创建存储过程,使用 while 批量插入数据