首页 >数据库 >mysql教程 >如何在 Python 中为持久连接启用 MySQLdb 中的自动客户端重新连接?

如何在 Python 中为持久连接启用 MySQLdb 中的自动客户端重新连接?

Linda Hamilton
Linda Hamilton原创
2024-11-22 12:06:11797浏览

How to Enable Automatic Client Re-connection in MySQLdb for Persistent Connections in Python?

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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn