mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #32546 -- Avoided Meta.ordering columns in GROUP BY clauses.
Follow up to 0ddb4ebf7b.
			
			
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							bc04941bf8
						
					
				
				
					commit
					330bc402a8
				
			| @@ -125,11 +125,12 @@ class SQLCompiler: | ||||
|             cols = expr.get_group_by_cols() | ||||
|             for col in cols: | ||||
|                 expressions.append(col) | ||||
|         for expr, (sql, params, is_ref) in order_by: | ||||
|             # Skip References to the select clause, as all expressions in the | ||||
|             # select clause are already part of the group by. | ||||
|             if not is_ref: | ||||
|                 expressions.extend(expr.get_group_by_cols()) | ||||
|         if not self._meta_ordering: | ||||
|             for expr, (sql, params, is_ref) in order_by: | ||||
|                 # Skip references to the SELECT clause, as all expressions in | ||||
|                 # the SELECT clause are already part of the GROUP BY. | ||||
|                 if not is_ref: | ||||
|                     expressions.extend(expr.get_group_by_cols()) | ||||
|         having_group_by = self.having.get_group_by_cols() if self.having else () | ||||
|         for expr in having_group_by: | ||||
|             expressions.append(expr) | ||||
|   | ||||
| @@ -2,7 +2,7 @@ from datetime import datetime | ||||
| from operator import attrgetter | ||||
|  | ||||
| from django.db.models import ( | ||||
|     CharField, DateTimeField, F, Max, OuterRef, Subquery, Value, | ||||
|     CharField, Count, DateTimeField, F, Max, OuterRef, Subquery, Value, | ||||
| ) | ||||
| from django.db.models.functions import Upper | ||||
| from django.test import TestCase | ||||
| @@ -484,3 +484,12 @@ class OrderingTests(TestCase): | ||||
|         ca4 = ChildArticle.objects.create(headline='h1', pub_date=datetime(2005, 7, 28)) | ||||
|         articles = ChildArticle.objects.order_by('article_ptr') | ||||
|         self.assertSequenceEqual(articles, [ca4, ca2, ca1, ca3]) | ||||
|  | ||||
|     def test_default_ordering_does_not_affect_group_by(self): | ||||
|         Article.objects.exclude(headline='Article 4').update(author=self.author_1) | ||||
|         Article.objects.filter(headline='Article 4').update(author=self.author_2) | ||||
|         articles = Article.objects.values('author').annotate(count=Count('author')) | ||||
|         self.assertCountEqual(articles, [ | ||||
|             {'author': self.author_1.pk, 'count': 3}, | ||||
|             {'author': self.author_2.pk, 'count': 1}, | ||||
|         ]) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user