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

用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()  

 

至此,问题解决。

 

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


  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值