{
  "id": "django__django-10880",
  "question": "Query syntax error with condition and distinct combination\nDescription\n\t\nA Count annotation containing both a Case condition and a distinct=True param produces a query error on Django 2.2 (whatever the db backend). A space is missing at least (... COUNT(DISTINCTCASE WHEN ...).\n",
  "answer": "{\"task_id\": \"0b62981f-7ad5-4ea9-b40c-3d7d4ac1d8bb\", \"workflow_run_id\": \"3bc0b068-4ffa-4799-ae66-0073c946a7e4\", \"data\": {\"id\": \"3bc0b068-4ffa-4799-ae66-0073c946a7e4\", \"workflow_id\": \"9a0a6efa-4d15-4876-b13f-4fb6a999caa2\", \"status\": \"succeeded\", \"outputs\": {\"final_patch\": [\"--- a/django/db/models/aggregates.py\\n+++ b/django/db/models/aggregates.py\\n@@ -82,7 +82,7 @@ class Count(Aggregate):\\n         if self.distinct:\\n             if len(self.source_expressions) > 1:\\n                 raise TypeError('COUNT DISTINCT with multiple fields is not supported.')\\n-            sql = 'DISTINCT' + sql\\n+            sql = 'DISTINCT ' + sql\\n         return self.filter(\\n             extra_context={'distinct': self.distinct},\\n             template=template % sql,\", \"--- a/django/db/models/aggregates.py\\n+++ b/django/db/models/aggregates.py\\n@@ -82,7 +82,7 @@ class Count(Aggregate):\\n         if self.distinct:\\n             if len(self.source_expressions) > 1:\\n                 raise TypeError('COUNT DISTINCT with multiple fields is not supported.')\\n-            sql = 'DISTINCT' + sql\\n+            sql = 'DISTINCT {}'.format(sql)\\n         return self.filter(\\n             extra_context={'distinct': self.distinct},\\n             template=template % sql,\", \"--- a/django/db/models/aggregates.py\\n+++ b/django/db/models/aggregates.py\\n@@ -82,7 +82,7 @@ class Count(Aggregate):\\n         if self.distinct:\\n             if len(self.source_expressions) > 1:\\n                 raise TypeError('COUNT DISTINCT with multiple fields is not supported.')\\n-            sql = 'DISTINCT' + sql\\n+            sql = f'DISTINCT {sql}'\\n         return self.filter(\\n             extra_context={'distinct': self.distinct},\\n             template=template % sql,\", \"--- a/django/db/models/aggregates.py\\n+++ b/django/db/models/aggregates.py\\n@@ -82,7 +82,7 @@ class Count(Aggregate):\\n         if self.distinct:\\n             if len(self.source_expressions) > 1:\\n                 raise TypeError('COUNT DISTINCT with multiple fields is not supported.')\\n-            sql = 'DISTINCT' + sql\\n+            sql = ' '.join(['DISTINCT', sql])\\n         return self.filter(\\n             extra_context={'distinct': self.distinct},\\n             template=template % sql,\", \"--- a/django/db/models/aggregates.py\\n+++ b/django/db/models/aggregates.py\\n@@ -82,7 +82,7 @@ class Count(Aggregate):\\n         if self.distinct:\\n             if len(self.source_expressions) > 1:\\n                 raise TypeError('COUNT DISTINCT with multiple fields is not supported.')\\n-            sql = 'DISTINCT' + sql\\n+            sql = 'DISTINCT' + ' ' + sql\\n         return self.filter(\\n             extra_context={'distinct': self.distinct},\\n             template=template % sql,\", \"diff\\n--- a/django/db/models/aggregates.py\\n+++ b/django/db/models/aggregates.py\\n@@ -82,7 +82,7 @@ class Count(Aggregate):\\n         if self.distinct:\\n             if len(self.source_expressions) > 1:\\n                 raise TypeError('COUNT DISTINCT with multiple fields is not supported.')\\n-            sql = 'DISTINCT' + sql\\n+            sql = 'DISTINCT ' + sql\\n         return self.filter(\\n             extra_context={'distinct': self.distinct},\\n             template=template % sql,\\n\", \"diff\\n--- a/django/db/models/aggregates.py\\n+++ b/django/db/models/aggregates.py\\n@@ -82,7 +82,7 @@ class Count(Aggregate):\\n         if self.distinct:\\n             if len(self.source_expressions) > 1:\\n                 raise TypeError('COUNT DISTINCT with multiple fields is not supported.')\\n-            sql = 'DISTINCT' + sql\\n+            sql = 'DISTINCT ' + sql\\n         return self.filter(\\n             extra_context={'distinct': self.distinct},\\n             template=template % sql,\\n\", \"diff\\n--- a/django/db/models/aggregates.py\\n+++ b/django/db/models/aggregates.py\\n@@ -82,7 +82,7 @@ class Count(Aggregate):\\n         if self.distinct:\\n             if len(self.source_expressions) > 1:\\n                 raise TypeError('COUNT DISTINCT with multiple fields is not supported.')\\n-            sql = 'DISTINCT' + sql\\n+            sql = 'DISTINCT ' + sql\\n         return self.filter(\\n             extra_context={'distinct': self.distinct},\\n             template=template % sql,\\n\"]}, \"error\": \"\", \"elapsed_time\": 82.286339, \"total_tokens\": 30526, \"total_steps\": 30, \"created_at\": 1754646735, \"finished_at\": 1754646817}}"
}