簡體   English   中英

Flask SQLAlchemy查詢:從自身外鍵關系過濾記錄

[英]Flask SQLAlchemy query: filter records from self foreign key relationship

我有一個具有自己的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布爾表達式作為位置參數,或者將關鍵字參數作為簡寫比較的簡寫形式。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM