Flask SQLAlchemy查询:从自己的外键关系中过滤记录

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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)状态子项的行。

答案

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

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

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

以上是关于Flask SQLAlchemy查询:从自己的外键关系中过滤记录的主要内容,如果未能解决你的问题,请参考以下文章

Flask-SQLAlchemy - 不使用外键连表查询。记得常回来看我

sqlalchemy外键和relationship查询

SQLAlchemy 命令式映射无法使用另一个实体的外键添加实体

flask 中orm关系映射 sqlalchemy的查询

flask SQLALchemy外键及约束

如何使用 Flask-SQLAlchemy 使用 csv 填充具有外键的模型?