1
0
mirror of https://github.com/django/django.git synced 2025-10-25 22:56:12 +00:00

Refs #34176 -- Adjusted group by position variables naming to follow SQL spec.

This avoids conceptual collisions with the notion of indices.
This commit is contained in:
Simon Charette
2023-02-18 01:11:51 -05:00
parent a6511bc233
commit f91e085c30

View File

@@ -142,10 +142,10 @@ class SQLCompiler:
# Note that even if the group_by is set, it is only the minimal # Note that even if the group_by is set, it is only the minimal
# set to group by. So, we need to add cols in select, order_by, and # set to group by. So, we need to add cols in select, order_by, and
# having into the select in any case. # having into the select in any case.
selected_expr_indices = {} selected_expr_positions = {}
for index, (expr, _, alias) in enumerate(select, start=1): for ordinal, (expr, _, alias) in enumerate(select, start=1):
if alias: if alias:
selected_expr_indices[expr] = index selected_expr_positions[expr] = ordinal
# Skip members of the select clause that are already explicitly # Skip members of the select clause that are already explicitly
# grouped against. # grouped against.
if alias in group_by_refs: if alias in group_by_refs:
@@ -174,9 +174,9 @@ class SQLCompiler:
continue continue
if ( if (
allows_group_by_select_index allows_group_by_select_index
and (select_index := selected_expr_indices.get(expr)) is not None and (position := selected_expr_positions.get(expr)) is not None
): ):
sql, params = str(select_index), () sql, params = str(position), ()
else: else:
sql, params = expr.select_format(self, sql, params) sql, params = expr.select_format(self, sql, params)
params_hash = make_hashable(params) params_hash = make_hashable(params)