mysql python reconnect
2020.04.24 23:05
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
db = DB()
sql = "SELECT * FROM foo"
cur = db.query(sql)
# wait a long time for the Mysql connection to timeout
cur = db.query(sql)
# still works
댓글 2
-
WHRIA
2020.04.24 23:10
-
WHRIA
2020.04.24 23:13
#!/usr/bin/env python import MySQLdb class DisconnectSafeCursor(object): db = None cursor = None def __init__(self, db, cursor): self.db = db self.cursor = cursor def close(self): self.cursor.close() def execute(self, *args, **kwargs): try: return self.cursor.execute(*args, **kwargs) except MySQLdb.OperationalError: self.db.reconnect() self.cursor = self.db.cursor() return self.cursor.execute(*args, **kwargs) def fetchone(self): return self.cursor.fetchone() def fetchall(self): return self.cursor.fetchall() class DisconnectSafeConnection(object): connect_args = None connect_kwargs = None conn = None def __init__(self, *args, **kwargs): self.connect_args = args self.connect_kwargs = kwargs self.reconnect() def reconnect(self): self.conn = MySQLdb.connect(*self.connect_args, **self.connect_kwargs) def cursor(self, *args, **kwargs): cur = self.conn.cursor(*args, **kwargs) return DisconnectSafeCursor(self, cur) def commit(self): self.conn.commit() def rollback(self): self.conn.rollback() disconnectSafeConnect = DisconnectSafeConnection
번호 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|
1656 | 이상한 사회현상들 | WHRIA | 2009.09.19 | 9015 |
1655 | gold | WHRIA | 2009.09.15 | 9002 |
1654 | 안녕하세염...저는.. | 그리니 | 2000.06.01 | 8941 |
1653 | ASUS 1215N | WHRIA | 2011.01.19 | 8894 |
1652 | 좋은 화장품 | WHRIA | 2012.07.11 | 8893 |
1651 | 과열된 증시 | WHRIA | 2009.09.19 | 8887 |
1650 | vs 2005 | WHRIA | 2008.02.22 | 8885 |
1649 | XP home 에서 동시 접속 늘리기 | WHRIA | 2012.08.25 | 8851 |
1648 | 곰녹음기 | WHRIA | 2013.01.22 | 8841 |
1647 | 어 이상하다 | 한석근 | 2000.06.08 | 8809 |
1646 | Nuvie Project | WHRIA | 2013.01.18 | 8808 |
1645 | Star excision [1] | WHRIA | 2007.08.14 | 8789 |
1644 | MSI U270 | WHRIA | 2011.04.27 | 8761 |
1643 | 남들이 괴로워할 때가 살 지점, 남들이 흥분할 때가 팔 시점 | WHRIA | 2009.09.14 | 8753 |
1642 | 개원은 1년을 넘겼고 이제 그냥 일들이 지나간다. | WHRIA | 2011.03.06 | 8727 |
https://stackoverflow.com/questions/207981/how-to-enable-mysql-client-auto-re-connect-with-mysqldb