• en
  • Language: ru
  • Documentation version: 2.0

14. Как использовать объекты Q для сложных запросов?

В предыдущих главах мы использовали объекты Q для операций OR и AND и NOT. Объекты Q обеспечивают полный контроль над пунктом where запроса.

Если вы хотите OR свои условия.

>>> from django.db.models import Q
>>> queryset = User.objects.filter(
    Q(first_name__startswith='R') | Q(last_name__startswith='D')
)
>>> queryset
<QuerySet [<User: Ricky>, <User: Ritesh>, <User: Radha>, <User: Raghu>, <User: rishab>]>

Если вы хотите AND свои условия.

>>> queryset = User.objects.filter(
    Q(first_name__startswith='R') & Q(last_name__startswith='D')
)
>>> queryset
<QuerySet [<User: Ricky>, <User: Ritesh>, <User: rishab>]>

Если вы хотите найти всех пользователей, чей first_name начинается с „R“, но не хотите, если last_name имеет „Z“

>>> queryset = User.objects.filter(
    Q(first_name__startswith='R') & ~Q(last_name__startswith='Z')
)

Если вы посмотрите на сформированный запрос, вы увидите

SELECT "auth_user"."id",
       "auth_user"."password",
       "auth_user"."last_login",
       "auth_user"."is_superuser",
       "auth_user"."username",
       "auth_user"."first_name",
       "auth_user"."last_name",
       "auth_user"."email",
       "auth_user"."is_staff",
       "auth_user"."is_active",
       "auth_user"."date_joined"
FROM "auth_user"
WHERE ("auth_user"."first_name"::text LIKE R%
       AND NOT ("auth_user"."last_name"::text LIKE Z%))

Вы можете комбинировать объекты Q более сложными способами для создания сложных запросов.