mirror of
https://github.com/django/django.git
synced 2025-10-24 06:06:09 +00:00
Fixed #24174 -- Fixed extra order by descending
This commit is contained in:
@@ -261,8 +261,10 @@ class SQLCompiler(object):
|
||||
# on verbatim.
|
||||
table, col = col.split('.', 1)
|
||||
order_by.append((
|
||||
OrderBy(RawSQL('%s.%s' % (self.quote_name_unless_alias(table), col), [])),
|
||||
False))
|
||||
OrderBy(
|
||||
RawSQL('%s.%s' % (self.quote_name_unless_alias(table), col), []),
|
||||
descending=descending
|
||||
), False))
|
||||
continue
|
||||
|
||||
if not self.query._extra or col not in self.query._extra:
|
||||
|
@@ -166,6 +166,26 @@ class OrderingTests(TestCase):
|
||||
attrgetter("headline")
|
||||
)
|
||||
|
||||
def test_extra_ordering_with_table_name(self):
|
||||
self.assertQuerysetEqual(
|
||||
Article.objects.extra(order_by=['ordering_article.headline']), [
|
||||
"Article 1",
|
||||
"Article 2",
|
||||
"Article 3",
|
||||
"Article 4",
|
||||
],
|
||||
attrgetter("headline")
|
||||
)
|
||||
self.assertQuerysetEqual(
|
||||
Article.objects.extra(order_by=['-ordering_article.headline']), [
|
||||
"Article 4",
|
||||
"Article 3",
|
||||
"Article 2",
|
||||
"Article 1",
|
||||
],
|
||||
attrgetter("headline")
|
||||
)
|
||||
|
||||
def test_order_by_pk(self):
|
||||
"""
|
||||
Ensure that 'pk' works as an ordering option in Meta.
|
||||
|
Reference in New Issue
Block a user