summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authormike bayer <mike_mp@zzzcomputing.com>2018-03-06 12:50:04 -0500
committerGerrit Code Review <gerrit@ci.zzzcomputing.com>2018-03-06 12:50:04 -0500
commitc5d79494d85e6ebd7f8e1d1e6f6c85db4a50ca85 (patch)
treefd896559cf3f8321147701a81aa154bdf1e6f35b /lib
parent59149b57027d87cc0e3a68c399d627096be9dd3e (diff)
parent611f7f4e94026926c8c85717e1a2d481bd2c5657 (diff)
downloadsqlalchemy-c5d79494d85e6ebd7f8e1d1e6f6c85db4a50ca85.tar.gz
Merge "Add Query.enable_single_entity()"
Diffstat (limited to 'lib')
-rw-r--r--lib/sqlalchemy/orm/loading.py3
-rw-r--r--lib/sqlalchemy/orm/query.py11
2 files changed, 13 insertions, 1 deletions
diff --git a/lib/sqlalchemy/orm/loading.py b/lib/sqlalchemy/orm/loading.py
index 2628093e0..3599aa3e7 100644
--- a/lib/sqlalchemy/orm/loading.py
+++ b/lib/sqlalchemy/orm/loading.py
@@ -37,7 +37,8 @@ def instances(query, cursor, context):
filtered = query._has_mapper_entities
- single_entity = len(query._entities) == 1 and \
+ single_entity = not query._only_return_tuples and \
+ len(query._entities) == 1 and \
query._entities[0].supports_single_entity
if filtered:
diff --git a/lib/sqlalchemy/orm/query.py b/lib/sqlalchemy/orm/query.py
index 1e7f8a266..043be5539 100644
--- a/lib/sqlalchemy/orm/query.py
+++ b/lib/sqlalchemy/orm/query.py
@@ -70,6 +70,7 @@ class Query(object):
"""
+ _only_return_tuples = False
_enable_eagerloads = True
_enable_assertions = True
_with_labels = False
@@ -604,6 +605,16 @@ class Query(object):
return self.enable_eagerloads(False).with_labels().statement
@_generative()
+ def only_return_tuples(self, value):
+ """When set to True, the query results will always be a tuple,
+ specifically for single element queries. The default is False.
+
+ . .. versionadded:: 1.2.5
+
+ """
+ self._only_return_tuples = value
+
+ @_generative()
def enable_eagerloads(self, value):
"""Control whether or not eager joins and subqueries are
rendered.