sqlalchemy錯誤:sqlalchemy.orm.exc.DetachedInstanceError


使用sqlchemy報錯。

sqlalchemy.orm.exc.DetachedInstanceError: Instance <User at 0x809ab1f> is not bound to a Session; attribute refresh operation cannot proceed (Background on this error at: http://sqlalche.me/e/bhk3)

解決方案:
將原
sessionmaker(bind=eng)
修改為
sessionmaker(bind=eng, expire_on_commit=False)

 

關於expire_on_commit:

expire_on_commit可以用來更改SQLAlchemy的對象刷新機制,默認值為True即在session調用commit之后會主動將同一個session在commit之前查詢得到的ORM對象的_sa_instance_state.expire屬性設置為Flase,再次讀取該對象屬性時將重載這個對象,方法是重新調用之前的查詢語句。

 

參考:

https://www.dazhuanlan.com/2019/12/23/5e004dedbc72d/#expire_on_commit

https://cloud.tencent.com/developer/ask/219084


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM