Джанго условная аннотация - PullRequest
8 голосов
/ 09 августа 2011

Я удивлен, что этого вопроса, видимо, еще не существует.Если это так, пожалуйста, помогите мне найти его.

Я хочу использовать annotate (Count) и order_by, но я не хочу считать каждый экземпляр связанного объекта, только те, которые соответствуют определенному критерию.

Для того, чтобы я мог перечислить ласточки по количеству зеленых кокосов, которые они несли:

swallow.objects.annotate(num_coconuts=Count('coconuts_carried__husk__color = "green"').order_by('num_coconuts')

Ответы [ 2 ]

8 голосов
/ 09 августа 2011

Это должен быть правильный путь.

swallow.objects.filter(
    coconuts_carried__husk__color="green"
).annotate(
    num_coconuts=Count('coconuts_carried')
).order_by('num_coconuts')

Обратите внимание, что при фильтрации по связанному полю в необработанном SQL оно переводится как LEFT JOIN плюс WHERE. В конце аннотация будет действовать на результирующий набор, который содержит только связанные строки, выбранные из первого фильтра.

3 голосов
/ 10 ноября 2016

Для Джанго> = 1,8:

from django.db.models import Sum, Case, When, IntegerField

swallow.objects.annotate(
    num_coconuts=Sum(Case(
        When(coconuts_carried__husk__color="green", then=1),
        output_field=IntegerField(),
    ))
).order_by('num_coconuts')
...