python 操作数据库 OperationalError: (2006, 'MySQL server has gone away') 解决方法

时间:2022-09-21 08:56:34

用python连接mysql数据库时有时会提示OperationalError: (2006, 'MySQL server has gone away')的错误,其原因主要是python与数据库的连接失败了,失败原因有多种,可能是提前关闭了连接,也有可能是由于超时连接而失败。最简单的方法就是多连几次数据库。

  1. class DB:  
  2.   conn = None  
  3.   cursor = None  
  4.   def connect(self):  
  5.     self.conn = MySQLdb.connect (host = global_srcDB_Host,  
  6.                              user = global_srcDB_User,  
  7.                              passwd = global_srcDB_PWD,  
  8.                              db = global_srcDB_DB)  
  9.   
  10.   def execute(self, sql):  
  11.     try:  
  12.       cursor = self.conn.cursor()  
  13.       cursor.execute(sql)  
  14.     except (AttributeError, MySQLdb.OperationalError):  
  15.       self.connect()  
  16.       cursor = self.conn.cursor()  
  17.       cursor.execute(sql)  
  18.     return cursor  
  19.   
  20.   def close(self):  
  21.     if(self.cursor):  
  22.       self.cursor.close()  
  23.     self.conn.commit()  
  24.     self.conn.close() 

使用如下:

db = DB()    

cursor = db.execute (sql)

db.close()  

 

至此,问题解决。

 

只要保证每次操作数据库之前连接数据库就可以。