Flask SQLAlchemy查询:从自身外键关系过滤记录

时间:2019-03-06 09:18:44

标签: python sqlalchemy flask-sqlalchemy

我有一个具有自我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)的子级的行。

1 个答案:

答案 0 :(得分:1)

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

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

any()可以将SQL布尔表达式作为位置参数,也可以将关键字参数作为简写比较的简写。