mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #23259 -- Corrected insertion order of extra() select_params
A regression caused queries to produce incorrect results for cases where
extra(select) is excluded by values() but included by extra(order_by)
The regression was caused by 2f35c6f10f.
			
			
This commit is contained in:
		
				
					committed by
					
						 Anssi Kääriäinen
						Anssi Kääriäinen
					
				
			
			
				
	
			
			
			
						parent
						
							12ad61aa9f
						
					
				
				
					commit
					f0b358880a
				
			| @@ -117,7 +117,7 @@ class SQLCompiler(object): | |||||||
|  |  | ||||||
|         if self.query.distinct: |         if self.query.distinct: | ||||||
|             result.append(self.connection.ops.distinct_sql(distinct_fields)) |             result.append(self.connection.ops.distinct_sql(distinct_fields)) | ||||||
|         params.extend(o_params) |  | ||||||
|         result.append(', '.join(out_cols + self.ordering_aliases)) |         result.append(', '.join(out_cols + self.ordering_aliases)) | ||||||
|         params.extend(s_params) |         params.extend(s_params) | ||||||
|         params.extend(self.ordering_params) |         params.extend(self.ordering_params) | ||||||
| @@ -146,6 +146,7 @@ class SQLCompiler(object): | |||||||
|  |  | ||||||
|         if ordering: |         if ordering: | ||||||
|             result.append('ORDER BY %s' % ', '.join(ordering)) |             result.append('ORDER BY %s' % ', '.join(ordering)) | ||||||
|  |             params.extend(o_params) | ||||||
|  |  | ||||||
|         if with_limits: |         if with_limits: | ||||||
|             if self.query.high_mark is not None: |             if self.query.high_mark is not None: | ||||||
|   | |||||||
| @@ -2130,6 +2130,26 @@ class ValuesQuerysetTests(BaseQuerysetTest): | |||||||
|             order_by=['value_minus_one']) |             order_by=['value_minus_one']) | ||||||
|         qs = qs.values('num') |         qs = qs.values('num') | ||||||
|  |  | ||||||
|  |     def test_extra_select_params_values_order_in_extra(self): | ||||||
|  |         # testing for 23259 issue | ||||||
|  |         qs = Number.objects.extra( | ||||||
|  |             select={'value_plus_x': 'num+%s'}, | ||||||
|  |             select_params=[1], | ||||||
|  |             order_by=['value_plus_x']) | ||||||
|  |         qs = qs.filter(num=72) | ||||||
|  |         qs = qs.values('num') | ||||||
|  |         self.assertQuerysetEqual(qs, [{'num': 72}], self.identity) | ||||||
|  |  | ||||||
|  |     def test_extra_multiple_select_params_values_order_by(self): | ||||||
|  |         # testing for 23259 issue | ||||||
|  |         qs = Number.objects.extra(select=OrderedDict([('value_plus_x', 'num+%s'), | ||||||
|  |                                                      ('value_minus_x', 'num-%s')]), | ||||||
|  |                                   select_params=(72, 72)) | ||||||
|  |         qs = qs.order_by('value_minus_x') | ||||||
|  |         qs = qs.filter(num=1) | ||||||
|  |         qs = qs.values('num') | ||||||
|  |         self.assertQuerysetEqual(qs, [], self.identity) | ||||||
|  |  | ||||||
|     def test_extra_values_list(self): |     def test_extra_values_list(self): | ||||||
|         # testing for ticket 14930 issues |         # testing for ticket 14930 issues | ||||||
|         qs = Number.objects.extra(select={'value_plus_one': 'num+1'}) |         qs = Number.objects.extra(select={'value_plus_one': 'num+1'}) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user