diff options
author | mike bayer <mike_mp@zzzcomputing.com> | 2021-07-09 21:29:40 +0000 |
---|---|---|
committer | Gerrit Code Review <gerrit@ci3.zzzcomputing.com> | 2021-07-09 21:29:40 +0000 |
commit | ca52e87268fec966f6005b1e4aa30206ae895e9e (patch) | |
tree | 179bd2b61fbb50c114e0617e06913b8c5917357b /lib/sqlalchemy/sql/selectable.py | |
parent | a457e555e0b1cc8aca79270f2330b5fdef78eafb (diff) | |
parent | 4e1b2ee4cb345f499bdfbff6c393efbebd8e1e72 (diff) | |
download | sqlalchemy-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.py | 15 |
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 |