--- /dev/null
+.. change::
+ :tags: feature, orm
+ :versions: 1.3.0b1
+
+ Added new feature :meth:`.Query.only_return_tuples`. Causes the
+ :class:`.Query` object to return keyed tuple objects unconditionally even
+ if the query is against a single entity. Pull request courtesy Eric
+ Atkin.
+
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:
"""
+ _only_return_tuples = False
_enable_eagerloads = True
_enable_assertions = True
_with_labels = False
def __clause_element__(self):
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
assert q1.session is s1
+class OnlyReturnTuplesTest(QueryTest):
+ def test_single_entity_false(self):
+ User = self.classes.User
+ row = create_session().query(User).only_return_tuples(False).first()
+ assert isinstance(row, User)
+
+ def test_single_entity_true(self):
+ User = self.classes.User
+ row = create_session().query(User).only_return_tuples(True).first()
+ assert isinstance(row, tuple)
+
+ def test_multiple_entity_false(self):
+ User = self.classes.User
+ row = create_session().query(User.id, User).only_return_tuples(False).first()
+ assert isinstance(row, tuple)
+
+ def test_multiple_entity_true(self):
+ User = self.classes.User
+ row = create_session().query(User.id, User).only_return_tuples(True).first()
+ assert isinstance(row, tuple)
+
+
class RowTupleTest(QueryTest):
run_setup_mappers = None