diff options
author | Mike Bayer <mike_mp@zzzcomputing.com> | 2019-08-29 12:09:17 -0400 |
---|---|---|
committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2019-08-30 17:57:38 -0400 |
commit | f6c9b20a04d183d86078252048563b14e27fb6d2 (patch) | |
tree | d8fbb764aa6322f56f2529fde793f937565bc96e /lib/sqlalchemy/sql/elements.py | |
parent | 2b042b6d18dc527c12b2ef1239bfe5ee2b658930 (diff) | |
download | sqlalchemy-f6c9b20a04d183d86078252048563b14e27fb6d2.tar.gz |
Annotate session-bind-lookup entity in Query-produced selectables
Added new entity-targeting capabilities to the :class:`.Query` object to
help with the case where the :class:`.Session` is using a bind dictionary
against mapped classes, rather than a single bind, and the :class:`.Query`
is against a Core statement that was ultimately generated from a method
such as :meth:`.Query.subquery`; a deep search is performed to locate
any ORM entity related to the query in order to locate a mapper if
one is not otherwise present.
Fixes: #4829
Change-Id: I95cf325a5aba21baec4b313246c6f4d692284820
Diffstat (limited to 'lib/sqlalchemy/sql/elements.py')
-rw-r--r-- | lib/sqlalchemy/sql/elements.py | 40 |
1 files changed, 8 insertions, 32 deletions
diff --git a/lib/sqlalchemy/sql/elements.py b/lib/sqlalchemy/sql/elements.py index e2df1adc2..19d26f138 100644 --- a/lib/sqlalchemy/sql/elements.py +++ b/lib/sqlalchemy/sql/elements.py @@ -22,6 +22,7 @@ from . import operators from . import roles from . import type_api from .annotation import Annotated +from .annotation import SupportsWrappingAnnotations from .base import _clone from .base import _generative from .base import Executable @@ -161,7 +162,7 @@ def not_(clause): @inspection._self_inspects -class ClauseElement(roles.SQLRole, Visitable): +class ClauseElement(roles.SQLRole, SupportsWrappingAnnotations, Visitable): """Base class for elements of a programmatically constructed SQL expression. @@ -267,37 +268,6 @@ class ClauseElement(roles.SQLRole, Visitable): d.pop("_is_clone_of", None) return d - def _annotate(self, values): - """return a copy of this ClauseElement with annotations - updated by the given dictionary. - - """ - return Annotated(self, values) - - def _with_annotations(self, values): - """return a copy of this ClauseElement with annotations - replaced by the given dictionary. - - """ - return Annotated(self, values) - - def _deannotate(self, values=None, clone=False): - """return a copy of this :class:`.ClauseElement` with annotations - removed. - - :param values: optional tuple of individual values - to remove. - - """ - if clone: - # clone is used when we are also copying - # the expression for a deep deannotation - return self._clone() - else: - # if no clone, since we have no annotations we return - # self - return self - def _execute_on_connection(self, connection, multiparams, params): if self.supports_execution: return connection._execute_clauseelement(self, multiparams, params) @@ -4136,6 +4106,12 @@ class ColumnClause(roles.LabeledColumnExprRole, Immutable, ColumnElement): self._memoized_property.expire_instance(self) self.__dict__["table"] = table + def get_children(self, column_tables=False, **kw): + if column_tables and self.table is not None: + return [self.table] + else: + return [] + table = property(_get_table, _set_table) def _cache_key(self, **kw): |