diff options
author | Simon Charette <charette.s@gmail.com> | 2023-02-27 01:10:19 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-02-27 07:10:19 +0100 |
commit | b15f162f252610e3b510ade465549769ab4356cf (patch) | |
tree | 76647400905e8d5b9b54f2330bbf22fcd45b6253 /django/db/models/sql/compiler.py | |
parent | 2276ec8c21655b05bb44e14e236b499aa5d01f5b (diff) | |
download | django-b15f162f252610e3b510ade465549769ab4356cf.tar.gz |
Fixed #34372 -- Fixed queryset crash on order by aggregation using OrderBy.
Regression in 278881e37619278789942513916acafaa88d26f3 caused by a lack
of expression copying when an OrderBy expression is explicitly provided.
Thanks Jannis Vajen for the report and regression test.
Diffstat (limited to 'django/db/models/sql/compiler.py')
-rw-r--r-- | django/db/models/sql/compiler.py | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/django/db/models/sql/compiler.py b/django/db/models/sql/compiler.py index 919e951fa2..e1a240dec3 100644 --- a/django/db/models/sql/compiler.py +++ b/django/db/models/sql/compiler.py @@ -358,11 +358,13 @@ class SQLCompiler: if ( field.nulls_first is None and field.nulls_last is None ) or self.connection.features.supports_order_by_nulls_modifier: + field = field.copy() field.expression = select_ref # Alias collisions are not possible when dealing with # combined queries so fallback to it if emulation of NULLS # handling is required. elif self.query.combinator: + field = field.copy() field.expression = Ref(select_ref.refs, select_ref.source) yield field, select_ref is not None continue |