mysql-回复DELETE数据

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql-回复DELETE数据相关的知识,希望对你有一定的参考价值。

参考技术A 测试小伙伴不小心执行了 DELETE * FROM 表名 语句,删除了测试服十几万条数据。因为测试还需要这些数据,所以只能进行恢复

1.找到mysql的日志文件binlog(二进制)
2.筛选出执行的DELETE语句,并重定向到文件中方便查看
当执行 DELETE * FROM 表名 语句时,实际上是对表内的数据一条条执行 DELETE FROM XXX WHERE XXXXXX 。而因为binlog文件很大(基本几百M起步),所以需要根据执行 DELETE * FROM xxx 语句的大概时间,进行筛选。语句: mysqlbinlog -vv --start-datetime='2020-06-10 10:10:00' binlog文件名 > 重定向文件名1
3.再根据重定向文件1中的内容再次筛选,比如我想要 DELETE FROM `xxxx`.`t_channel 这一行以及下面13行的内容。所以我会再次进行筛选并重定向生成新的文件: cat 重定向文件名1 -C 13 `DELETE FROM `xxxx`.`t_channel` > 重定向文件名2 ,这样我会得到一个只包含 DELETE FROM XXX WHERE XXXXXX 语句的文件。

PS.

参考: https://blog.csdn.net/weixin_33811961/article/details/89593855

MYSQL误删除DELETE数据找回

1.查看binlog是否开启

show variables like '%log_bin%';

2.查看数据文件存放路径:bin-log路径

show variables like '%datadir%';

3.找到删除时间段的binlog,翻译为sql

mysqlbinlog --base64-output=decode-rows -v --database=数据库名 --start-datetime="2022-10-19 16:40:00" --stop-datetime="2022-10-19 16:450:00" "D:\\Program Files\\mysql-5.7.30-winx64\\mysqldb\\bin.000041" > d:\\mysqllog.sql

4.在生成的 mysqllog.sql 文件同路径下 ,生成将delete翻译为insert的sql文件
linux:

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

5、windows:
在生成的sql文件同目录下,创建.vbs文件,写入如下内容,并双击执行
'==========================
'用VBS实现 MYSQL binglog DELETE转INSERT
'==========================
function replaceregex(patern,str,tagstr)
dim regex,matches
set regex=new regExp
regex.pattern=patern
regex.IgnoreCase=true
regex.global=true
matches=regex.replace(str,tagstr)
replaceregex=matches
end function

'Mysql binlog DELETE转INSERT==========
'VBS打开文本文件
Set oldStream = CreateObject(“ADODB.Stream”)
oldStream.CharSet = “utf-8”
oldStream.Open
oldStream.LoadFromFile(“mysqllog.sql”) 'binLog生成的DELETE原日志文件
oldText = oldStream.ReadText()
newText=replace(oldText,“### DELETE FROM”, “;INSERT INTO”)
newText=replace(newText,“### WHERE”, “SELECT”)
newText=replace(newText,“###”, “”)
newText=replace(newText,“@1=”, “”)
newText=replaceregex(“@[1-9]=”,newText, “,”)
newText=replaceregex(“@[1-9][0-9]=”,newText, “,”)
oldStream.Close
'VBS保存文件
Set newStream = CreateObject(“ADODB.Stream”)
newStream.Type = 2 'Specify stream type - we want To save text/string data.
newStream.Charset = “utf-8” 'Specify charset For the source text data.
newStream.Open 'Open the stream And write binary data To the object
newStream.WriteText newText
newStream.SaveToFile “mysqllogOK.sql”, 2 'DELETE转成INSERT以后的新的SQL文件名
newStream.Close

6、把mysqllog.sql文件和生成的windows中的.vbs放在同一个文件夹中双击执行生成mysqllogOK.sql文件
7、进入mysqllogOK.sql文件删除其中的delete保留insert再去执行mysqllogOK.sql就成功了
8、如果binlog日志没有开启可以进行开启
linux:

cd /usr/etc/
vim my.cnf

log-bin=mysql-bin # 开启Binlog 一般只需要修改这一行即可
binlog-format=ROW # 设置格式 此行可以不加 命令设置即可 详见下方拓展
server_id=1 # 配置serverID 这一行本来就存在
systemctl restart mysqld #重启mysql

以上是关于mysql-回复DELETE数据的主要内容,如果未能解决你的问题,请参考以下文章

MYSQL:如何清空表中的数据 truncate delete

mysql delete数据时报Error Code 1175

MySQL ------ 删除数据(DELETE) (二十二)

MySQL ------ 删除数据(DELETE) (二十二)

mysql数据库delete数据时不支持表别名!!!

Mysql数据库delete删除后数据恢复报告