gpt4 book ai didi

python - SQLAlchemy 池连接关闭异常

转载 作者:太空宇宙 更新时间:2023-11-04 05:48:29 24 4
gpt4 key购买 nike

任何人都知道为什么每当 SQLAlchemy 池中的连接关闭时(conn.close()),我都会收到此异常:

ERROR:Exception during reset or similar       
Traceback (most recent call last):
File "/usr/local/lib/python2.7/dist-packages/sqlalchemy/pool.py", line 631, in _finalize_fairy
fairy._reset(pool)
File "/usr/local/lib/python2.7/dist-packages/sqlalchemy/pool.py", line 771, in _reset
pool._dialect.do_rollback(self)
File "/usr/local/lib/python2.7/dist-packages/sqlalchemy/pool.py", line 83, in do_rollback
dbapi_connection.rollback()
File "/usr/local/lib/python2.7/dist-packages/sqlalchemy/pool.py", line 850, in __getattr__
return getattr(self.connection, key)
AttributeError: 'Connection' object has no attribute 'rollback'

我正在使用 SQLAlchemy==1.0.6 连接到 mysql,这是我的代码的一部分:

self.__engine = create_engine("mysql+mysqldb://%s:%s@%s/%s?charset=utf8&use_unicode=0" %(config['db_user'], config['db_passwd'], config['db_host'], config['db']), pool_recycle=3600)
self.__mypool = pool.QueuePool(self.__getConn, pool_size=config['db_pool_size'])
conn = self.__mypool.connect()
results = conn.execute(statement, values)
conn.close()

最佳答案

似乎在当前版本的 SQLAlchemy 中(在某些版本之前可以工作),队列池已经集成到 create_engine() 中。它不喜欢单独创建 QueuePool()。以下更改解决了该问题:

self.__mypool = create_engine("mysql+mysqldb://%s:%s@%s/%s?charset=utf8&use_unicode=0" %(config['db_user'], config['db_passwd'], config['db_host'], config['db']), pool_size=config['db_pool_size'], pool_recycle=3600)
conn = self.__mypool.connect()
results = conn.execute(statement, values)
conn.close()

关于python - SQLAlchemy 池连接关闭异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31240919/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com