diff options
author | Mike Bayer <mike_mp@zzzcomputing.com> | 2019-10-11 14:45:24 -0400 |
---|---|---|
committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2019-10-16 13:33:01 -0400 |
commit | 33119301bb3efa143ebaaef22a7b5170f14a1331 (patch) | |
tree | 3097d7db5f2defabad7792539a8048f3c95c5c0c /lib/sqlalchemy/orm/attributes.py | |
parent | 657ec85e8733c64b9be2154c3169d31c15a06dce (diff) | |
download | sqlalchemy-33119301bb3efa143ebaaef22a7b5170f14a1331.tar.gz |
Implement raiseload for deferred columns
Added "raiseload" feature for ORM mapped columns.
As part of this change, the behavior of "deferred" is now more strict;
an attribute that is set up as "deferred" at the mapper level no longer
participates in an "unexpire" operation; that is, when an unexpire loads
all the expired columns of an object which are not themselves in a deferred
group, those which are mapper-level deferred will never be loaded.
Deferral options set at query time should always be reset by an expiration
operation.
Renames deferred_scalar_loader to expired_attribute_loader
Unfortunately we can't have raiseload() do this because it would break
existing wildcard behavior.
Fixes: #4826
Change-Id: I30d9a30236e0b69134e4094fb7c1ad2267f089d1
Diffstat (limited to 'lib/sqlalchemy/orm/attributes.py')
-rw-r--r-- | lib/sqlalchemy/orm/attributes.py | 18 |
1 files changed, 11 insertions, 7 deletions
diff --git a/lib/sqlalchemy/orm/attributes.py b/lib/sqlalchemy/orm/attributes.py index 1466f5f47..83069f113 100644 --- a/lib/sqlalchemy/orm/attributes.py +++ b/lib/sqlalchemy/orm/attributes.py @@ -468,7 +468,7 @@ class AttributeImpl(object): compare_function=None, active_history=False, parent_token=None, - expire_missing=True, + load_on_unexpire=True, send_modified_events=True, accepts_scalar_loader=None, **kwargs @@ -503,10 +503,13 @@ class AttributeImpl(object): Allows multiple AttributeImpls to all match a single owner attribute. - :param expire_missing: - if False, don't add an "expiry" callable to this attribute - during state.expire_attributes(None), if no value is present - for this key. + :param load_on_unexpire: + if False, don't include this attribute in a load-on-expired + operation, i.e. the "expired_attribute_loader" process. + The attribute can still be in the "expired" list and be + considered to be "expired". Previously, this flag was called + "expire_missing" and is only used by a deferred column + attribute. :param send_modified_events: if False, the InstanceState._modified_event method will have no @@ -534,7 +537,7 @@ class AttributeImpl(object): if active_history: self.dispatch._active_history = True - self.expire_missing = expire_missing + self.load_on_unexpire = load_on_unexpire self._modified_token = Event(self, OP_MODIFIED) __slots__ = ( @@ -546,7 +549,7 @@ class AttributeImpl(object): "parent_token", "send_modified_events", "is_equal", - "expire_missing", + "load_on_unexpire", "_modified_token", "accepts_scalar_loader", ) @@ -683,6 +686,7 @@ class AttributeImpl(object): if ( self.accepts_scalar_loader + and self.load_on_unexpire and key in state.expired_attributes ): value = state._load_expired(state, passive) |