Этот вопрос проверяет знание агрегирующих функций Django ORM и умение различать объектные вычисления и группировки.
Метод annotate() добавляет вычисляемые поля к каждому объекту в QuerySet — например, количество связанных записей. Метод aggregate() возвращает один итоговый результат для всего набора данных.annotate() → построчные вычисления,aggregate() → один общий итог (SUM, COUNT, AVG и т.п.).
В Django ORM методы annotate() и aggregate() позволяют использовать агрегирующие функции SQL, такие как COUNT, SUM, AVG, MAX, MIN.
Однако работают они по-разному и служат разным задачам.
Назначение: добавить новое поле, вычисляемое SQL-агрегатом, к каждому элементу выборки.
Пример: считаем число комментариев у каждой статьи.
python
from django.db.models import Count
articles = Article.objects.annotate(total_comments=Count('comments'))
Каждый объект Article получит поле .total_comments.
Назначение: вернуть итоговое значение, а не QuerySet.
Пример:
python
from django.db.models import Avg
average_age = User.objects.aggregate(avg_age=Avg('age'))
Результат:
{'avg_age': 27.5}
возвращает QuerySet
добавляет вычисления к каждому объекту
формирует SQL c GROUP BY
возвращает словарь
выполняет один итоговый запрос
не создаёт группировок, если они не нужны
Пример:
python
Article.objects.annotate(total=Count('comments')).aggregate(sum=Sum('total'))
annotate() → добавить поле с вычислениями на каждый объект.aggregate() → получить итоговое значение по всей выборке.
Уровень
Рейтинг:
5
Сложность:
5
Навыки
Python
Django
Ключевые слова
Подпишись на Python Developer в телеграм