Python

解决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()
(0)

本文由 SilenceLee的学习笔记 作者:silencelee 发表,转载请注明来源!

热评文章

发表评论

解决 : *
18 + 29 =