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 的可执行性

你可能感兴趣的:(Flask,python,flask)