Расширенные запросы в MongoEngine

Иногда, вызывая объект QuerySet с какими то параметрами вы не можете в полной мере описать запрос который вам нужен. Например если вам нужно отфильтровать документы по lдвум или больше параметрам.


Для того чтобы получить документы по двум и более запросам одновременно у MongoEngine имеется класс Q.

from mongoengine import Q

Объект Q представляет собой часть запроса, и может быть инициализирован, используя тот же синтаксис, что и для запроса документов. Для построения сложного запроса вы можете объединить объекты Q с помощью операторов & (логическое и) и | (логическое или). Чтобы организовать сложную фильтрацию с использованием объекта Q, передайте его в качестве первого аргумента Document.objects с необходимыми параметрами.


Пример №1

animals = Animals.objects(Q(hunters=True) & Q(size=big)).all()

В данном примере мы получаем всех животных, являющимися крупными хищниками.


Пример №2

cars = Cars.objects(Q(brand=toyota) & (Q(color=white) | Q(color=grey))).all()

А тут мы получаем черные и серые машины марки toyota



Обратите внимание! Разрешено использование только битовых операторов & и |. Использование вместо них логических and и or, приведет к неправильному выполнению запроса.

Так запрос:

animals = Animals.objects(Q(hunters=True) and Q(size=big)).all()

Будет обработан как:

animals = Animals.objects(Q(hunters=True)).all()
 

Вот так. Вроде бы ничего сложного. В дальнейшем я расскажу о других возможностях сложных запросов в MongoEngine.