Sqlalchemy 使用 in or notin 无法批量删除或者修改数据

下面以删除为例,update和delete和修改一模一样的

1. 解决方法

可以在delete()括号内添加 synchronize_session=False 或者 synchronize_session=‘fetch’ 实现删除

delete(synchronize_session=False)

2. 出现的场景

当我们使用 in 或者 notin 筛选出需要删除的数据并进行删的时候

_m = MpSubscribeScheduled
update_list = db.session.query(_m).filter(_m.id.in_(times_list)).update({_m.canceled: False})

通常会出现以下错误:

sqlalchemy.exc.InvalidRequestError: Could not evaluate current criteria in Python. Specify ‘fetch’ or False for the synchronize_session parameter

3.原因解析

delete(synchronize_session='evaluate')
# synchronize_session=False : 该参数不会同步删除数据,而是在session结束前删除数据
# synchronize_session=‘evaluate’ : 该参数会先评估查询删除的可执行性,如果无法执行就会报错,不支持in or notin
# synchronize_session=‘fetch’ : 该参数会将会先查找一次对象,然后在将对象移除session并删除

这是因为delete(synchronize_session=‘evaluate’) 的默认参数为synchronize_session=‘evaluate’, 会评估session 的可执行性

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值