完成MySQL回滾的Python劇本的編寫教程。本站提示廣大學習愛好者:(完成MySQL回滾的Python劇本的編寫教程)文章只能為提供參考,不一定能成為您想要的結果。以下是完成MySQL回滾的Python劇本的編寫教程正文
操作數據庫時刻不免會由於“年夜意”而誤操作,須要疾速恢復的話經由過程備份來恢復是不太能夠的,由於須要復原和binlog差來恢復,等不了,很費時。這裡先解釋下由於Delete 操作的恢復辦法:重要照樣經由過程binlog來停止恢復,條件是binlog_format必需是Row格局,不然只能經由過程備份來恢單數據了。
辦法:
前提:開啟Binlog,Format為Row。
步調:
1.經由過程MySQL自帶對象mysqlbinlog 指定導出操作的記載:
mysqlbinlog --no-defaults --start-datetime='2012-12-25 14:56:00' --stop-datetime='2012-12-25 14:57:00' -vv mysql-bin.000001 > /home/zhoujy/restore/binlog.txt
2.數據掏出來以後,須要把數據解析反轉,原始數據:
### DELETE FROM test.me_info ### WHERE ### @1=2165974 /* INT meta=0 nullable=0 is_null=0 */ ### @2='1984:03:17' /* DATE meta=0 nullable=1 is_null=0 */ ### @3=NULL /* DATE meta=765 nullable=1 is_null=1 */ ### @4=2012-10-25 00:00:00 /* DATETIME meta=0 nullable=0 is_null=0 */ ### @5='' /* VARSTRING(765) meta=765 nullable=1 is_null=0 */ ### @6=0 /* TINYINT meta=0 nullable=1 is_null=0 */ ### @7='' /* VARSTRING(765) meta=765 nullable=1 is_null=0 */ ### @8=-1 (4294967295) /* INT meta=0 nullable=1 is_null=0 */ ### @9=0 /* MEDIUMINT meta=0 nullable=1 is_null=0 */ ### @10=NULL /* MEDIUMINT meta=0 nullable=1 is_null=1 */ ### @11=2 /* TINYINT meta=0 nullable=1 is_null=0 */ ### @12=0 /* TINYINT meta=0 nullable=1 is_null=0 */ ### @13='' /* VARSTRING(765) meta=765 nullable=1 is_null=0 */ ### @14='' /* VARSTRING(765) meta=765 nullable=1 is_null=0 */ ### @15=0 /* MEDIUMINT meta=0 nullable=1 is_null=0 */ ### @16=320 /* INT meta=0 nullable=1 is_null=0 */ …………………… …………………… ……………………
Row格局的binlog記載的格局如下面所示,須要做的任務就是吧Delete的操作轉換成Insert操作,發下面的都是有必定紀律的,而且須要留意的是:
1、字段類型 DATETIME 日期。在日記中保留的格局為 @4=2012-10-25 00:00:00,須要將2012-10-25 00:00:00加上引號。
2、正數。在日記中保留的格局為 @1=-1 (4294967295), -2(4294967294),-3(4294967293),須要將()外面的數據去失落,只保存@1=-1。
3、本義字符集。如:'s,\,等。
下面3點清晰以後,可以寫一個劇本(程度無限,在晉升中,寫的欠好看):
#!/bin/env python # -*- encoding: utf-8 -*- #------------------------------------------------------------------------------- # Name: restore.py # Purpose: 經由過程Binlog恢復Delete誤操作數據 # Author: zhoujy # Created: 2012-12-25 # update: 2012-12-25 # Copyright: (c) Mablevi 2012 # Licence: zjy #------------------------------------------------------------------------------- def read_binlog(file,column_num): f=open(file) num = '@'+str(column_num) while True: lines = f.readline() if lines.strip()[0:3] == '###': lines=lines.split(' ',3) if lines[1] == 'DELETE' and lines[2] =='FROM': #該部門調換Delete為Insert lines[1] = "INSERT" lines[2] = 'INTO' lines[-1] = lines[-1].strip() if lines[1].strip() == 'WHERE': lines[1] = 'VALUES (' if ''.join(lines).find('@') <> -1 and lines[3].split('=',1)[0] <> num: #num為列數,如果小於最年夜的列數,前面均加, lines[3] = lines[3].split('=',1)[-1].strip() if lines[3].strip('\'').strip().find('\'') <> -1: lines[3] = lines[3].split('/*')[0].strip('\'').strip().strip('\'').replace('\\','').replace('\'','\\\'') #這裡過濾失落本義的字符串 lines[3] = '\'' + lines[3] + '\',' elif lines[3].find('INT meta') <> -1: #過濾Int類型的字段為正數後帶的(),負數不受影響 lines[3] = lines[3].split('/*')[0].strip() lines[3] = lines[3].split()[0] + ',' elif lines[3].find('NULL') <> -1: lines[3] = lines[3].split('/*')[0].strip() lines[3] = lines[3] + ',' else: lines[3] = lines[3].split('/*')[0].strip('\'').strip().strip('\'').replace('\\','').replace('\'','\\\'') #這裡過濾失落本義的字符串 lines[3] = '\'' + lines[3].strip('\''' ') + '\',' if ''.join(lines).find('@') <> -1 and lines[3].split('=',1)[0] == num: #num為列數,如果小於最年夜的列數,前面均加); lines[3] = lines[3].split('=',1)[-1].strip() if lines[3].find('\'') <> -1: lines[3] = lines[3].split('/*')[0].strip('\'').strip().strip('\'').replace('\\','').replace('\'','\\\'') #同上 lines[3] = '\'' + lines[3] + '\');' elif lines[3].find('INT meta') <> -1: #同上 lines[3] = lines[3].split('/*')[0].strip() lines[3] = lines[3].split(' ')[0] + ');' elif lines[3].find('NULL') <> -1: lines[3] = lines[3].split('/*')[0].strip() lines[3] = lines[3] + ');' else: lines[3] = lines[3].split('/*')[0].strip('\'').strip().strip('\'').replace('\\','').replace('\'','\\\'') #同上 lines[3] = '\'' + lines[3].strip('\''' ') + '\');' print ' '.join(lines[1:]) if lines == '': break if __name__ == '__main__': import sys read_binlog(sys.argv[1],sys.argv[2])履行劇本:
python restore.py binlog.txt 36 > binlog.sql
敕令行中的36 表現 須要復原的表的字段有36個,後果:
INSERT INTO test.me_info VALUES ( 2123269, '1990:11:12', NULL, 2, '', 0, '', -1, 0, 340800, 1, 0, '', …… …… 1, NULL );
最初復原:
mysql test < binlog.sql