下面以删除为例,update和delete和修改一模一样的
可以在delete()括号内添加 synchronize_session=False 或者 synchronize_session=‘fetch’ 实现删除
delete(synchronize_session=False)
当我们使用 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
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 的可执行性