MySQLdb:启用自动客户端重新连接
在 Python 中,MySQLdb 库提供了一种与 MySQL 数据库交互的便捷方式。一个常见的挑战是在暂时中断的情况下保持持久连接。
为了解决这个问题,PHP 中存在一种涉及 MySQL 选项的解决方案,但用户在使用 MySQLdb 复制它时遇到困难。
解决方案:
MySQLdb中启用自动重连的关键在于包装cursor.execute()
以下 Python 代码演示了一个解决方案:
import MySQLdb class DB: conn = None def connect(self): self.conn = MySQLdb.connect() def query(self, sql): try: cursor = self.conn.cursor() cursor.execute(sql) except (AttributeError, MySQLdb.OperationalError): self.connect() cursor = self.conn.cursor() cursor.execute(sql) return cursor # Example usage db = DB() sql = "SELECT * FROM foo" cur = db.query(sql) # Sleep for a long time to simulate connection timeout time.sleep(60 * 60 * 24) cur = db.query(sql) # Connection is still valid and usable
在这种方法中,query() 函数代表用户管理连接,确保任何丢失的连接都可以重新连接。自动建立。
以上是如何在 Python 中为持久连接启用 MySQLdb 中的自动客户端重新连接?的详细内容。更多信息请关注PHP中文网其他相关文章!