mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Refs #20939 -- Moved subquery ordering clearing optimization to the __in lookup.
Queries could potentially be resolved in cases where ordering matter.
This commit is contained in:
		| @@ -367,9 +367,18 @@ class In(FieldGetDbPrepValueIterableMixin, BuiltinLookup): | ||||
|             placeholder = '(' + ', '.join(sqls) + ')' | ||||
|             return (placeholder, sqls_params) | ||||
|         else: | ||||
|             if not getattr(self.rhs, 'has_select_fields', True): | ||||
|                 self.rhs.clear_select_clause() | ||||
|                 self.rhs.add_fields(['pk']) | ||||
|             from django.db.models.sql.query import Query  # avoid circular import | ||||
|             if isinstance(self.rhs, Query): | ||||
|                 query = self.rhs | ||||
|                 # It's safe to drop ordering if the queryset isn't using | ||||
|                 # slicing, distinct(*fields), or select_for_update(). | ||||
|                 if (query.low_mark == 0 and query.high_mark is None and | ||||
|                         not query.distinct_fields and | ||||
|                         not query.select_for_update): | ||||
|                     query.clear_ordering(True) | ||||
|                 if not query.has_select_fields: | ||||
|                     query.clear_select_clause() | ||||
|                     query.add_fields(['pk']) | ||||
|             return super().process_rhs(compiler, connection) | ||||
|  | ||||
|     def get_rhs_op(self, connection, rhs): | ||||
|   | ||||
| @@ -981,12 +981,6 @@ class Query: | ||||
|         # Subqueries need to use a different set of aliases than the outer query. | ||||
|         clone.bump_prefix(query) | ||||
|         clone.subquery = True | ||||
|         # It's safe to drop ordering if the queryset isn't using slicing, | ||||
|         # distinct(*fields) or select_for_update(). | ||||
|         if (self.low_mark == 0 and self.high_mark is None and | ||||
|                 not self.distinct_fields and | ||||
|                 not self.select_for_update): | ||||
|             clone.clear_ordering(True) | ||||
|         return clone | ||||
|  | ||||
|     def prepare_lookup_value(self, value, lookups, can_reuse, allow_joins=True): | ||||
|   | ||||
		Reference in New Issue
	
	Block a user