Kaydet (Commit) 07577a2d authored tarafından Simon Charette's avatar Simon Charette

Fixed #25081 -- Prevented DISTINCT ON ordering from being cleared in get().

Thanks to pdewacht for the patch.
üst 7b6d3104
...@@ -376,7 +376,7 @@ class QuerySet(object): ...@@ -376,7 +376,7 @@ class QuerySet(object):
keyword arguments. keyword arguments.
""" """
clone = self.filter(*args, **kwargs) clone = self.filter(*args, **kwargs)
if self.query.can_filter(): if self.query.can_filter() and not self.query.distinct_fields:
clone = clone.order_by() clone = clone.order_by()
num = len(clone) num = len(clone)
if num == 1: if num == 1:
......
...@@ -129,3 +129,11 @@ class DistinctOnTests(TestCase): ...@@ -129,3 +129,11 @@ class DistinctOnTests(TestCase):
qs, [self.p1_o2, self.p2_o1, self.p3_o1], qs, [self.p1_o2, self.p2_o1, self.p3_o1],
lambda x: x lambda x: x
) )
def test_distinct_on_get_ordering_preserved(self):
"""
Ordering shouldn't be cleared when distinct on fields are specified.
refs #25081
"""
staff = Staff.objects.distinct('name').order_by('name', '-organisation').get(name='p1')
self.assertEqual(staff.organisation, 'o2')
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment