我有一个像这样的自我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
)状态子项的行。
执行EXISTS
查询的最简单方法是使用any()
和has()
关系方法:
# Note the use of ~ operator for NOT
Foo.query.filter(~Foo.sub_foo.any(status=0))
any()
接受SQL布尔表达式作为位置参数,或接受关键字参数作为简单相等比较的缩写。