170 похожих чатов

Есть какие то модели Model1 и Model2, при этом у

Model2 есть fk на Model1 и какой то аттрибут attr2
Как можно с помощью annotate вывести количество обьектов Model1, у которых существует связь с обьектами Model2 и у этих обьектов attr2 не None?

Делаю так:
Model1.objects.values(‘attr1’).annotate(total=Count(Case(When(model2__attr2__isnull=False), then=1)).order_by(‘total’)
Получаю количество обьектов Model2, для которых выполняется условие вместо кол-ва обьектов Model1

3 ответов

20 просмотров
Illia- Автор вопроса

ап в надежде на ответ

сделай фильтер потом подсчитай скок получилось, типо такого Model1.objects.filter(model2__attr2__isnull=False).values(‘attr1’).annotate(total=Count('attr1')).order_by(‘total’) Model1.objects.filter(model2__attr2__isnull=False).annotate(total=Count('attr1')).values(‘attr1’, 'total').order_by(‘total’)

Illia- Автор вопроса

Фильтровать надо именно внутри annotate, я хочу вернуть общее кол-во, кол-во обьектов с related objects с атрибутом None и кол-во обьектов c related objects с атрибутом не None. Я понимаю, что это все можно достать разными запросами в бд, но хочется получить один кверисет со всеми данными за один раз Сори, что не уточнил сразу

Похожие вопросы

Обсуждают сегодня

У меня это всегда вопрос вызывало.. Нафига писать код так, чтобы потом ошибки вылавливать?
Nik
44
что за асемблер кста?
Shvabrikk Nya
19
Добрый день! Пробую отловить исключение EConvertError: function _TryTextToDouble(var DoubleVar: Extended; Text: String): Boolean; begin try DoubleVar := StrToFloat...
Kirill Filippenok
19
А где @Grinyaha уважаемый пропал?
Am Ambrion
14
Сделал краткий обзор магазина из статьи и заодно там же записал инструкцию по развёртыванию. https://www.youtube.com/watch?v=8-sE1vNk95Q (чё думаете по звуку? кое-что поменял...
Andrey K
17
Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Привет, коллеги! Возникла задача ограничить максимальный размер вложений для определённых расширений, например, чтобы для изображений лимит был 10 МБ, а для видео — 100 МБ. Ог...
Andro
1
вот не понимаю, зачем вообще лезть в осдев, если даже базы не знаешь? хотя бы про загрузку, форматы файлов железо какое-никакое. Ну реально, даже зная работу железа, с условны...
Mixail Frolov
7
Можно ли ставить FPC транк, а Лазарь нет?
А Андрей
9
Мужики и девушки, привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных...
Kraszx
14
Карта сайта