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