解決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