Categories: Python

Расширенные запросы в 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()
admin

Share
Published by
admin

Recent Posts

Настройка Mercurial по HTTPS

Иногда mercurial, при скачивании и комитах ругается на https. Особенно на самоподписанные сертификаты. Чтобы заработал…

3 недели ago

Компиляция libvirt в Ubuntu

Компиляция libvirt Подробнее

3 недели ago

Ошибка libvirt permission denied: решение

Если возникает ошибка libvirt destroy lxc permission denied , при попытке остановить контейнер: _x000D_# virsh…

3 недели ago

Настройка редиректа в NGINX

Файлы с примерами редиректа для nginx Подробнее

3 недели ago

Включение gzip в NGINX

Как включить gzip сжатие в Nginx ? Подробнее

3 недели ago

Удаление postinst-скрипта в Linux

Иногда возникает ситуация, когда криво настроенные пакеты не устанавливаются в системе. У меня это произошло…

3 недели ago