程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> 完成MySQL回滾的Python劇本的編寫教程

完成MySQL回滾的Python劇本的編寫教程

編輯:MySQL綜合教程

完成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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved