为什么flask sqlalchemy模型查询没有得到最新记录?

2024-02-19

我有一个模型类:

class PlatformUsage(db.Model):
    __tablename__ = 'platform_usage'

    id = db.Column(db.BigInteger, primary_key=True)
    module = db.Column(db.String(64))
    rb = db.Column(db.BigInteger)
    status = db.Column(db.String(64))
    platform = db.Column(db.String(64))

    def __init__(self, module, rb, status, platform):
        self.module = module
        self.rb = rb
        self.status = status
        self.platform = platform

    def __repr__(self):
       return "<PlatformUsage(module: %s, rb: %d, status: %s, platform: %s>" % (
           self.module, self.rb, self.status, self.platform)

当我这样查询时:

while True:
  PlatformUsage.query.filter_by(module='xxx')

我在外部更改数据库,无法获得最新结果!为什么 ?

session.query(PlatformUsage).filter_by(xxxx) 

就会得到正确的结果!


Mikko Ohtamaa 链接到的问题不会立即回答您的问题,但包含您需要了解才能理解的内容。

第一次执行查询后,您就处于事务中。在事务中,大多数 DBMS 保证您可重复读取(或为您提供该选项)。 IE。每次在事务中运行查询时你会得到相同的答案。这就是执行第一个代码时发生的情况。

在第二个交易中,您可能在浏览器上按 F5,然后您会收到一笔新交易。这为您提供了最新数据。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

为什么flask sqlalchemy模型查询没有得到最新记录? 的相关文章

随机推荐