mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Fixed #29118 -- Fixed crash with QuerySet.order_by(Exists(...)).
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							1a1264f149
						
					
				
				
					commit
					bf26f66029
				
			| @@ -1041,11 +1041,11 @@ class Exists(Subquery): | |||||||
|     def __invert__(self): |     def __invert__(self): | ||||||
|         return type(self)(self.queryset, negated=(not self.negated), **self.extra) |         return type(self)(self.queryset, negated=(not self.negated), **self.extra) | ||||||
|  |  | ||||||
|     def resolve_expression(self, query=None, **kwargs): |     def resolve_expression(self, query=None, *args, **kwargs): | ||||||
|         # As a performance optimization, remove ordering since EXISTS doesn't |         # As a performance optimization, remove ordering since EXISTS doesn't | ||||||
|         # care about it, just whether or not a row matches. |         # care about it, just whether or not a row matches. | ||||||
|         self.queryset = self.queryset.order_by() |         self.queryset = self.queryset.order_by() | ||||||
|         return super().resolve_expression(query, **kwargs) |         return super().resolve_expression(query, *args, **kwargs) | ||||||
|  |  | ||||||
|     def as_sql(self, compiler, connection, template=None, **extra_context): |     def as_sql(self, compiler, connection, template=None, **extra_context): | ||||||
|         sql, params = super().as_sql(compiler, connection, template, **extra_context) |         sql, params = super().as_sql(compiler, connection, template, **extra_context) | ||||||
|   | |||||||
| @@ -15,3 +15,5 @@ Bugfixes | |||||||
| * Prioritized the datetime and time input formats without ``%f`` for the Thai | * Prioritized the datetime and time input formats without ``%f`` for the Thai | ||||||
|   locale to fix the admin time picker widget displaying "undefined" |   locale to fix the admin time picker widget displaying "undefined" | ||||||
|   (:ticket:`29109`). |   (:ticket:`29109`). | ||||||
|  |  | ||||||
|  | * Fixed crash with ``QuerySet.order_by(Exists(...))`` (:ticket:`29118`). | ||||||
|   | |||||||
| @@ -38,10 +38,8 @@ class BasicExpressionsTests(TestCase): | |||||||
|             name="Foobar Ltd.", num_employees=3, num_chairs=4, |             name="Foobar Ltd.", num_employees=3, num_chairs=4, | ||||||
|             ceo=Employee.objects.create(firstname="Frank", lastname="Meyer", salary=20) |             ceo=Employee.objects.create(firstname="Frank", lastname="Meyer", salary=20) | ||||||
|         ) |         ) | ||||||
|         cls.gmbh = Company.objects.create( |         cls.max = Employee.objects.create(firstname='Max', lastname='Mustermann', salary=30) | ||||||
|             name="Test GmbH", num_employees=32, num_chairs=1, |         cls.gmbh = Company.objects.create(name='Test GmbH', num_employees=32, num_chairs=1, ceo=cls.max) | ||||||
|             ceo=Employee.objects.create(firstname="Max", lastname="Mustermann", salary=30) |  | ||||||
|         ) |  | ||||||
|  |  | ||||||
|     def setUp(self): |     def setUp(self): | ||||||
|         self.company_query = Company.objects.values( |         self.company_query = Company.objects.values( | ||||||
| @@ -399,6 +397,14 @@ class BasicExpressionsTests(TestCase): | |||||||
|         ) |         ) | ||||||
|         self.assertEqual(str(qs.query).count('JOIN'), 2) |         self.assertEqual(str(qs.query).count('JOIN'), 2) | ||||||
|  |  | ||||||
|  |     def test_order_by_exists(self): | ||||||
|  |         mary = Employee.objects.create(firstname='Mary', lastname='Mustermann', salary=20) | ||||||
|  |         mustermanns_by_seniority = Employee.objects.filter(lastname='Mustermann').order_by( | ||||||
|  |             # Order by whether the employee is the CEO of a company | ||||||
|  |             Exists(Company.objects.filter(ceo=OuterRef('pk'))).desc() | ||||||
|  |         ) | ||||||
|  |         self.assertSequenceEqual(mustermanns_by_seniority, [self.max, mary]) | ||||||
|  |  | ||||||
|     def test_outerref(self): |     def test_outerref(self): | ||||||
|         inner = Company.objects.filter(point_of_contact=OuterRef('pk')) |         inner = Company.objects.filter(point_of_contact=OuterRef('pk')) | ||||||
|         msg = ( |         msg = ( | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user