mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +00:00 
			
		
		
		
	[1.9.x] Fixed #24019 -- Fixed inaccurate docs about GenericRelation not supporting aggregation.
This works at least as far back as Django 1.6 according to the test
added in refs #10870.
Backport of e19bd086d6 from master
			
			
This commit is contained in:
		| @@ -455,18 +455,12 @@ signal. | |||||||
| Generic relations and aggregation | Generic relations and aggregation | ||||||
| --------------------------------- | --------------------------------- | ||||||
|  |  | ||||||
| :doc:`Django's database aggregation API </topics/db/aggregation>` | :doc:`Django's database aggregation API </topics/db/aggregation>` works with a | ||||||
| doesn't work with a |  | ||||||
| :class:`~django.contrib.contenttypes.fields.GenericRelation`. For example, you | :class:`~django.contrib.contenttypes.fields.GenericRelation`. For example, you | ||||||
| might be tempted to try something like:: | can find out how many tags all the bookmarks have:: | ||||||
|  |  | ||||||
|     Bookmark.objects.aggregate(Count('tags')) |     >>> Bookmark.objects.aggregate(Count('tags')) | ||||||
|  |     {'tags__count': 3} | ||||||
| This will not work correctly, however. The generic relation adds extra filters |  | ||||||
| to the queryset to ensure the correct content type, but the |  | ||||||
| :meth:`~django.db.models.query.QuerySet.aggregate` method doesn't take them |  | ||||||
| into account. For now, if you need aggregates on generic relations, you'll |  | ||||||
| need to calculate them without using the aggregation API. |  | ||||||
|  |  | ||||||
| .. module:: django.contrib.contenttypes.forms | .. module:: django.contrib.contenttypes.forms | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user