SQLAlchemy的“缓存”问题导致的BUG

2018-07-04 02:16:18来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

问题描述:

  最近做项目,遇到一个问题,两个项目操作同一个数据库,其中A项目用的pymysql链接操作数据库,B项目用的sqlalchemy,当我请求B项目中的一个接口,会通知A项目操作数据库,然后返回结果后,B项目再进行下一个操作(这两步是在一个接口中),但是后来发现,A成功添加了数据后,在同一个请求中,B进行查询数据时,查询不到刚刚更新的数据,后来想了想可能是存在缓存问题,缓存问题可以参考下面这个文章

参考:https://www.jianshu.com/p/c0a8275cce99

解决问题:

在B进行查询数据前先db.session.commit()一下,这个操作会将当前session对象里面的缓存全部提交,清空缓存,下次查询时,就是从数据库中查询最新数据,而不是先查询缓存

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:养成这7个良好的编程习惯,可以很大程度上增加你的Python性能

下一篇:《11招玩转网络安全》之第一招:Docker For Docker