mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Refs #33482 -- Fixed QuerySet selecting and filtering againts negated Exists() with empty queryset.
Regression in b7d1da5a62.
			
			
This commit is contained in:
		| @@ -1221,7 +1221,10 @@ class Exists(Subquery): | |||||||
|             ) |             ) | ||||||
|         except EmptyResultSet: |         except EmptyResultSet: | ||||||
|             if self.negated: |             if self.negated: | ||||||
|                 return '', () |                 features = compiler.connection.features | ||||||
|  |                 if not features.supports_boolean_expr_in_select_clause: | ||||||
|  |                     return "1=1", () | ||||||
|  |                 return compiler.compile(Value(True)) | ||||||
|             raise |             raise | ||||||
|         if self.negated: |         if self.negated: | ||||||
|             sql = 'NOT {}'.format(sql) |             sql = 'NOT {}'.format(sql) | ||||||
|   | |||||||
| @@ -1918,6 +1918,14 @@ class ExistsTests(TestCase): | |||||||
|         ) |         ) | ||||||
|         self.assertSequenceEqual(qs, [manager]) |         self.assertSequenceEqual(qs, [manager]) | ||||||
|  |  | ||||||
|  |     def test_select_negated_empty_exists(self): | ||||||
|  |         manager = Manager.objects.create() | ||||||
|  |         qs = Manager.objects.annotate( | ||||||
|  |             not_exists=~Exists(Manager.objects.none()) | ||||||
|  |         ).filter(pk=manager.pk) | ||||||
|  |         self.assertSequenceEqual(qs, [manager]) | ||||||
|  |         self.assertIs(qs.get().not_exists, True) | ||||||
|  |  | ||||||
|  |  | ||||||
| class FieldTransformTests(TestCase): | class FieldTransformTests(TestCase): | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user