Flask SQLAlchemy запрос: отфильтровать записи по отношению к самому внешнему ключу - PullRequest
0 голосов
/ 06 марта 2019

У меня есть класс модели с собственным отношением 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 Ответ

1 голос
/ 06 марта 2019

Самый простой способ выполнить EXISTS запросы - использовать методы отношений any() и has():

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

any() принимает либо логические выражения SQL в качестве позиционных аргументов, либо аргументы ключевых слов в качестве сокращений для простых сравнений на равенство.

...