当前位置:   article > 正文

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

sqlalchemy not in

下面以删除为例,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})
  • 1
  • 2

通常会出现以下错误:

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

3.原因解析

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

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/凡人多烦事01/article/detail/409646
推荐阅读
相关标签
  

闽ICP备14008679号