【问题标题】:Flask SQLAlchemy query: filter records from self foreign key relationshipFlask SQLAlchemy 查询:从自外键关系中过滤记录
【发布时间】:2019-03-06 17:29:03
【问题描述】:

我有一个具有自身 ForeignKey 关系的模型类,如下所示:

class Foo(db.Model):
    id = Column(db.Integer, primary_key=True)
    name = Column(db.String(320))
    status = Column(db.Integer) # 0: undone, 1:done
    parent_id = Column(db.Integer, db.ForeignKey('foo.id'), index=True)
    parent = db.relationship(lambda: Foo, remote_side=id, backref='sub_foo')

我需要过滤没有子代或全部完成 (status == 1) 子代的行。 换句话说,我需要排除具有未完成 (status == 0) 状态的子项的行。

【问题讨论】:

    标签: python sqlalchemy flask-sqlalchemy


    【解决方案1】:

    执行EXISTS 查询的最简单方法是使用any()has() 关系方法:

    # Note the use of ~ operator for NOT
    Foo.query.filter(~Foo.sub_foo.any(status=0))
    

    any() 接受 SQL 布尔表达式作为位置参数,或关键字参数作为简单相等比较的简写。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-05-24
      • 2017-08-28
      • 2016-05-08
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多