日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

window下Mysql 恢复Delete删除的数据

發布時間:2023/12/19 综合教程 28 生活家
生活随笔 收集整理的這篇文章主要介紹了 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

總結

以上是生活随笔為你收集整理的window下Mysql 恢复Delete删除的数据的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。