解决pymysql.err.InterfaceError: (0, '')报错的办法


# pymysql.err.InterfaceError: (0, '')报错原因:
# 在网上查了下,是因为这个数据库的连接建立太久了,会自动断开,这个时候我们需要重新建立连接,否则访问接口就会出现异常报错了。

'''
解决方法:
每次操作SQL之前对连接进行检查,如果发现连接已经断开,则进行重连。
在 pymysql 创建的数据库连接对象下,有这么一个方法:ping()
使用该方法 ping(reconnect=True) ,那么可以在每次连接之前,会检查当前连接是否已关闭,如果连接关闭则会重新进行连接。
'''

def execute_db(self, sql):
    try:
        # 检查连接是否断开,如果断开就进行重连
        self.conn.ping(reconnect=True)
        self.cur.execute(sql)
        self.conn.commit()
    except Exception as e:
        print("操作出现错误:{}".format(e))
        self.conn.rollback()


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM