db.session.query(Article).filter(Article.id.in_(items)).delete()
报错:
sqlalchemy.exc.InvalidRequestError
InvalidRequestError: Could not evaluate current criteria in Python. Specify 'fetch' or False for the synchronize_session parameter.
但是:
db.session.query(Article).filter(Article.id==1).delete()
db.session.query(Article).filter(Article.id.in_(items))
都能得到正确的结果。为什么不能直接使用.delete()?
我按下面的写法能正常工作。
art_items=Article.query.filter(Article.id.in_(items))
for item in art_items:
db.session.delete(item)
db.session.commit()
就是希望了解一下原理。为什么不能在使用_in的时候直接后面接delete()?