Запрос Flask SQLAlchemy: фильтровать записи по отношению к собственному внешнему ключу

#python #sqlalchemy #flask-sqlalchemy

#python #sqlalchemy #flask-sqlalchemy

Вопрос:

У меня есть класс модели с отношением к собственному внешнему ключу, подобным этому:

 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 ).
Другими словами, мне нужно исключить строки, у которых есть дочерние элементы со статусом undone ( status == 0 ).

Ответ №1:

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

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

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