使用scoped_session在事务内调取commit方法报sqlalchemy.exc.ResourceClosedError: This transaction is closed

时间: 2024-03-15 22:45:48 浏览: 15
`scoped_session` 通常用于管理会话的生命周期,它会为每个线程创建一个会话,并在线程结束时自动关闭会话。但是,如果你在使用 `scoped_session` 时手动控制事务,可能会遇到这个问题。 这个错误通常是由于在事务关闭后尝试使用连接或事务引起的。在使用 `scoped_session` 进行数据库操作时,需要注意在适当的时候提交事务,否则会引起这个错误。你可以尝试在事务内调用 `commit` 方法,如下所示: ```python from sqlalchemy.orm import scoped_session, sessionmaker from sqlalchemy import create_engine engine = create_engine('mysql://user:password@localhost/db_name') Session = scoped_session(sessionmaker(bind=engine)) session = Session() try: # 在事务内进行数据库操作 session.add(...) session.commit() except: session.rollback() raise finally: # 在事务结束后关闭会话 session.close() ``` 在这个例子中,我们手动控制了事务,确保在事务结束时调用了 `commit` 方法,并在 `finally` 块中关闭了会话。
相关问题

AttributeError: 'scoped_session' object has no attribute '_autoflush'

这个错误通常发生在使用 SQLAlchemy ORM 操作数据库时。它表示你正在尝试在一个被标记为 "scoped_session" 的会话上执行一个不受支持的操作。 一个可能的解决方法是在创建 "scoped_session" 对象时,将参数 autoflush 设置为 True,如下所示: ``` from sqlalchemy.orm import scoped_session, sessionmaker Session = scoped_session(sessionmaker(autoflush=True)) ``` 如果你已经创建了 "scoped_session" 对象,你可以尝试手动设置 autoflush 属性,如下所示: ``` from sqlalchemy.orm import scoped_session session = scoped_session(...) session.autoflush = True ``` 这应该能够解决该错误。如果问题仍然存在,请提供更多的上下文信息,以便我能够帮助你更好地解决问题。

app.route('/deleteaccount/<int:account_id>', methods=['POST']) @login_required def delete_account(account_id) : authed = session.get('authed') if not authed : return redirect(url_for('login')) form1 = DeleteAccountForm() account = User.query.get_or_404(account_id) if form1.submit.data and form1.validate() : if current_user.id != account.id : abort(401) flash('Usurpation') logout_user() db.session.delete(account) db.session.commit() session.pop('authed') flash('Disposed') else : abort(400) return redirect(url_for('login')) @db.event.listens_for(User, 'after_delete', named=True) def edit_account(**kwargs) : target = kwargs['target'] for username in [target.username] : if username is not None : dis = Photo.query.filter_by(user_name=username).delete() db.session.begin(subtransactions=True) db.session.commit() ,报错信息:TypeError: scoped_session.begin() got an unexpected keyword argument 'subtransactions',修改报错

在你的代码中,`scoped_session` 不支持 `subtransactions` 参数。你可以使用 `session.begin_nested()` 代替 `scoped_session.begin(subtransactions=True)`,以实现嵌套事务。 以下是修改后的代码: ``` @app.route('/deleteaccount/<int:account_id>', methods=['POST']) @login_required def delete_account(account_id): authed = session.get('authed') if not authed: return redirect(url_for('login')) form1 = DeleteAccountForm() account = User.query.get_or_404(account_id) if form1.submit.data and form1.validate(): if current_user.id != account.id: abort(401) flash('Usurpation') logout_user() db.session.delete(account) db.session.commit() session.pop('authed') flash('Disposed') else: abort(400) return redirect(url_for('login')) @db.event.listens_for(User, 'after_delete', named=True) def edit_account(**kwargs): target = kwargs['target'] for username in [target.username]: if username is not None: dis = Photo.query.filter_by(user_name=username).delete() nested = db.session.begin_nested() nested.commit() ```

相关推荐

最新推荐

recommend-type

解决java maven项目找不到jconsole-1.8.0.jar和tools-1.8.0.jar包问题

主要介绍了解决java maven项目找不到jconsole-1.8.0.jar和tools-1.8.0.jar包问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

Vue scoped及deep使用方法解析

主要介绍了Vue scoped及deep使用方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
recommend-type

详解Vue中的scoped及穿透方法

主要介绍了Vue中的scoped及穿透方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

深入浅析Vue中的slots/scoped slots

主要介绍了Vue中的slots/scoped slots,本文实例代码相结合的形式给大家介绍了slots的工作原理,需要的朋友可以参考下
recommend-type

解决vue加scoped后就无法修改vant的UI组件的样式问题

有时候UI组件提供的默认的样式不能满足项目的需要,就需要我们对它的样式进行修改,但是发现加了scoped后修改的样式不起作用。 解决方法: 使用深度选择器,将scoped样式中的选择器“深入”,即影响子组件 &lt;...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

机器学习怎么将excel转为csv文件

机器学习是一种利用计算机算法和统计数据的方法来训练计算机来进行自动学习的科学,无法直接将excel文件转为csv文件。但是可以使用Python编程语言来读取Excel文件内容并将其保存为CSV文件。您可以使用Pandas库来读取Excel文件,并使用to_csv()函数将其保存为CSV格式。以下是代码示例: ```python import pandas as pd # 读取 Excel 文件 excel_data = pd.read_excel('example.xlsx') # 将数据保存为 CSV 文件 excel_data.to_csv('example.csv', index=
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。