sqlalchemy DetachedInstanceError: Instance <Users at 0xaed0fd0> is not bound to a Session

1、代码如下:

data_list = db.session.query(Users).all
data_list = q.all()

for item in data_list:
	try:
		if not item:
			continue
		if not item.CODE:
			continue			

		body_position = UserDto()
		body_position.CODE = item.CODE
		body_position.POS = item['POS']

		update_user_pos(body_position)
	except Exception as e:
        LOGGER.error(str(e))
				
def update_user_pos(dto: UserDto)
    try:
        db.session.query(Users).filter(Users.CODE == dto.CODE)\
            .update({"POS": dto.POS})
        db.session.commit()
    except Exception as ex:
        db.session.rollback()
	finally:
		db.session.remove()

2、因为在update_user_pos中将session移除了,在第二次获取item.CODE时就会报错

3、处理方式:移除db.session.remove()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值