mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +00:00 
			
		
		
		
	[2.1.x] Fixed #29694 -- Fixed column mismatch crash with QuerySet.values() or values_list() after combining querysets with extra() with union(), difference(), or intersection().
Regression in0b66c3b442. Backport of39461a83c3from master
This commit is contained in:
		| @@ -411,7 +411,11 @@ class SQLCompiler: | |||||||
|                 # must have the same columns list. Set the selects defined on |                 # must have the same columns list. Set the selects defined on | ||||||
|                 # the query on all combined queries, if not already set. |                 # the query on all combined queries, if not already set. | ||||||
|                 if not compiler.query.values_select and self.query.values_select: |                 if not compiler.query.values_select and self.query.values_select: | ||||||
|                     compiler.query.set_values((*self.query.values_select, *self.query.annotation_select)) |                     compiler.query.set_values(( | ||||||
|  |                         *self.query.extra_select, | ||||||
|  |                         *self.query.values_select, | ||||||
|  |                         *self.query.annotation_select, | ||||||
|  |                     )) | ||||||
|                 parts += (compiler.as_sql(),) |                 parts += (compiler.as_sql(),) | ||||||
|             except EmptyResultSet: |             except EmptyResultSet: | ||||||
|                 # Omit the empty queryset with UNION and with DIFFERENCE if the |                 # Omit the empty queryset with UNION and with DIFFERENCE if the | ||||||
|   | |||||||
| @@ -41,3 +41,8 @@ Bugfixes | |||||||
|  |  | ||||||
| * Fixed admin change view crash for view-only users if the form has an extra | * Fixed admin change view crash for view-only users if the form has an extra | ||||||
|   form field (:ticket:`29682`). |   form field (:ticket:`29682`). | ||||||
|  |  | ||||||
|  | * Fixed a regression in Django 2.0.5 where ``QuerySet.values()`` or | ||||||
|  |   ``values_list()`` after combining querysets with ``extra()`` with | ||||||
|  |   ``union()``, ``difference()``, or ``intersection()`` crashed due to | ||||||
|  |   mismatching columns (:ticket:`29694`). | ||||||
|   | |||||||
| @@ -130,6 +130,13 @@ class QuerySetSetOperationTests(TestCase): | |||||||
|         ).values_list('num', 'count') |         ).values_list('num', 'count') | ||||||
|         self.assertCountEqual(qs1.union(qs2), [(1, 0), (2, 1)]) |         self.assertCountEqual(qs1.union(qs2), [(1, 0), (2, 1)]) | ||||||
|  |  | ||||||
|  |     def test_union_with_extra_and_values_list(self): | ||||||
|  |         qs1 = Number.objects.filter(num=1).extra( | ||||||
|  |             select={'count': 0}, | ||||||
|  |         ).values_list('num', 'count') | ||||||
|  |         qs2 = Number.objects.filter(num=2).extra(select={'count': 1}) | ||||||
|  |         self.assertCountEqual(qs1.union(qs2), [(1, 0), (2, 1)]) | ||||||
|  |  | ||||||
|     def test_union_with_values_list_on_annotated_and_unannotated(self): |     def test_union_with_values_list_on_annotated_and_unannotated(self): | ||||||
|         ReservedName.objects.create(name='rn1', order=1) |         ReservedName.objects.create(name='rn1', order=1) | ||||||
|         qs1 = Number.objects.annotate( |         qs1 = Number.objects.annotate( | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user