summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy/sql/selectable.py
diff options
context:
space:
mode:
authormike bayer <mike_mp@zzzcomputing.com>2021-07-09 21:29:40 +0000
committerGerrit Code Review <gerrit@ci3.zzzcomputing.com>2021-07-09 21:29:40 +0000
commitca52e87268fec966f6005b1e4aa30206ae895e9e (patch)
tree179bd2b61fbb50c114e0617e06913b8c5917357b /lib/sqlalchemy/sql/selectable.py
parenta457e555e0b1cc8aca79270f2330b5fdef78eafb (diff)
parent4e1b2ee4cb345f499bdfbff6c393efbebd8e1e72 (diff)
downloadsqlalchemy-ca52e87268fec966f6005b1e4aa30206ae895e9e.tar.gz
Merge "Add additional support to honor _proxy_key in Core selects"
Diffstat (limited to 'lib/sqlalchemy/sql/selectable.py')
-rw-r--r--lib/sqlalchemy/sql/selectable.py15
1 files changed, 9 insertions, 6 deletions
diff --git a/lib/sqlalchemy/sql/selectable.py b/lib/sqlalchemy/sql/selectable.py
index 0092fe094..235c74ea7 100644
--- a/lib/sqlalchemy/sql/selectable.py
+++ b/lib/sqlalchemy/sql/selectable.py
@@ -5815,14 +5815,17 @@ class Select(
repeated = c._anon_name_label in names
names[c._anon_name_label] = c
return (None, c, repeated)
+ else:
+ name = effective_name = c._label
elif getattr(c, "name", None) is None:
# this is a scalar_select(). need to improve this case
- repeated = c._anon_name_label in names
- names[c._anon_name_label] = c
- return (None, c, repeated)
-
- if use_tablename_labels:
- name = effective_name = c._label
+ expr_label = c._expression_label
+ if expr_label is None:
+ repeated = c._anon_name_label in names
+ names[c._anon_name_label] = c
+ return (None, c, repeated)
+ else:
+ name = effective_name = expr_label
else:
name = None
effective_name = c.name