mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Fixed #26517 -- Fixed ExpressionWrapper with empty queryset.
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							1410616e0e
						
					
				
				
					commit
					c002a0d39f
				
			| @@ -223,7 +223,12 @@ class SQLCompiler(object): | |||||||
|  |  | ||||||
|         ret = [] |         ret = [] | ||||||
|         for col, alias in select: |         for col, alias in select: | ||||||
|             ret.append((col, self.compile(col, select_format=True), alias)) |             try: | ||||||
|  |                 sql, params = self.compile(col, select_format=True) | ||||||
|  |             except EmptyResultSet: | ||||||
|  |                 # Select a predicate that's always False. | ||||||
|  |                 sql, params = '0', () | ||||||
|  |             ret.append((col, (sql, params), alias)) | ||||||
|         return ret, klass_info, annotations |         return ret, klass_info, annotations | ||||||
|  |  | ||||||
|     def get_order_by(self): |     def get_order_by(self): | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ from decimal import Decimal | |||||||
| from django.core.exceptions import FieldDoesNotExist, FieldError | from django.core.exceptions import FieldDoesNotExist, FieldError | ||||||
| from django.db.models import ( | from django.db.models import ( | ||||||
|     BooleanField, CharField, Count, DateTimeField, ExpressionWrapper, F, Func, |     BooleanField, CharField, Count, DateTimeField, ExpressionWrapper, F, Func, | ||||||
|     IntegerField, Sum, Value, |     IntegerField, Q, Sum, Value, | ||||||
| ) | ) | ||||||
| from django.db.models.functions import Lower | from django.db.models.functions import Lower | ||||||
| from django.test import TestCase, skipUnlessDBFeature | from django.test import TestCase, skipUnlessDBFeature | ||||||
| @@ -148,6 +148,19 @@ class NonAggregateAnnotationTestCase(TestCase): | |||||||
|         combined = int(test.pages + test.rating) |         combined = int(test.pages + test.rating) | ||||||
|         self.assertEqual(b.combined, combined) |         self.assertEqual(b.combined, combined) | ||||||
|  |  | ||||||
|  |     def test_empty_expression_annotation(self): | ||||||
|  |         books = Book.objects.annotate( | ||||||
|  |             selected=ExpressionWrapper(Q(pk__in=[]), output_field=BooleanField()) | ||||||
|  |         ) | ||||||
|  |         self.assertEqual(len(books), Book.objects.count()) | ||||||
|  |         self.assertTrue(all(not book.selected for book in books)) | ||||||
|  |  | ||||||
|  |         books = Book.objects.annotate( | ||||||
|  |             selected=ExpressionWrapper(Q(pk__in=Book.objects.none()), output_field=BooleanField()) | ||||||
|  |         ) | ||||||
|  |         self.assertEqual(len(books), Book.objects.count()) | ||||||
|  |         self.assertTrue(all(not book.selected for book in books)) | ||||||
|  |  | ||||||
|     def test_annotate_with_aggregation(self): |     def test_annotate_with_aggregation(self): | ||||||
|         books = Book.objects.annotate( |         books = Book.objects.annotate( | ||||||
|             is_book=Value(1, output_field=IntegerField()), |             is_book=Value(1, output_field=IntegerField()), | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user