mirror of
https://github.com/django/django.git
synced 2025-10-26 15:16:09 +00:00
Fixed #10425 -- Corrected the interaction of .count() with .annotate() when .values() is also involved. Thanks to kmassey for the report.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@10053 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
@@ -329,7 +329,7 @@ class BaseQuery(object):
|
||||
Performs a COUNT() query using the current filter constraints.
|
||||
"""
|
||||
obj = self.clone()
|
||||
if len(self.select) > 1:
|
||||
if len(self.select) > 1 or self.aggregate_select:
|
||||
# If a select clause exists, then the query has already started to
|
||||
# specify the columns that are to be returned.
|
||||
# In this case, we need to use a subquery to evaluate the count.
|
||||
@@ -1950,6 +1950,7 @@ class BaseQuery(object):
|
||||
# Clear out the select cache to reflect the new unmasked aggregates.
|
||||
self.aggregates = {None: count}
|
||||
self.set_aggregate_mask(None)
|
||||
self.group_by = None
|
||||
|
||||
def add_select_related(self, fields):
|
||||
"""
|
||||
|
||||
Reference in New Issue
Block a user