From 65858119d23e37872505a4476e7141c33981fb50 Mon Sep 17 00:00:00 2001 From: Simon Charette Date: Mon, 21 Jan 2019 08:24:32 -0600 Subject: [PATCH] Fixed #30120 -- Fixed invalid SQL in distinct aggregate. Regression in bc05547cd8c1dd511c6b6a6c873a1bc63417b111 (refs #28658). --- django/db/models/aggregates.py | 2 +- tests/aggregation/tests.py | 7 +++++++ 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/django/db/models/aggregates.py b/django/db/models/aggregates.py index ac0b62d0bf..ea88c54b0d 100644 --- a/django/db/models/aggregates.py +++ b/django/db/models/aggregates.py @@ -68,7 +68,7 @@ class Aggregate(Func): return [] def as_sql(self, compiler, connection, **extra_context): - extra_context['distinct'] = 'DISTINCT' if self.distinct else '' + extra_context['distinct'] = 'DISTINCT ' if self.distinct else '' if self.filter: if connection.features.supports_aggregate_filter_clause: filter_sql, filter_params = self.filter.as_sql(compiler, connection) diff --git a/tests/aggregation/tests.py b/tests/aggregation/tests.py index 8cac90f020..3820496c9f 100644 --- a/tests/aggregation/tests.py +++ b/tests/aggregation/tests.py @@ -8,6 +8,7 @@ from django.db.models import ( Avg, Count, DecimalField, DurationField, F, FloatField, Func, IntegerField, Max, Min, Sum, Value, ) +from django.db.models.expressions import Case, When from django.test import TestCase from django.test.utils import Approximate, CaptureQueriesContext from django.utils import timezone @@ -395,6 +396,12 @@ class AggregateTestCase(TestCase): sql = ctx.captured_queries[0]['sql'] self.assertIn('SELECT COUNT(*) ', sql) + def test_count_distinct_expression(self): + aggs = Book.objects.aggregate( + distinct_ratings=Count(Case(When(pages__gt=300, then='rating')), distinct=True), + ) + self.assertEqual(aggs['distinct_ratings'], 4) + def test_non_grouped_annotation_not_in_group_by(self): """ An annotation not included in values() before an aggregate should be