2011-02-11 168 views
0

我有两个模型。与django重组奋斗

项目和支持者模型。

我想基本上运行一个查询,返回支持者最多的项目。

是否重组实现此目标的唯一方法?

class Project(models.Model): 
    owner = models.ForeignKey(User) 
    project_name = models.CharField(max_length=50, help_text='Lorem ipsum dolor sit amet.') 

class Backer(models.Model): 
    user = models.ForeignKey(User) 
    project = models.ForeignKey(Project) 
    amount = models.PositiveIntegerField() 

我已经试过如下:

{% regroup backers by project as backers_list %} 
{% for obj in backers_list %} 
    <strong>{{ obj.grouper }}</strong><br /> 
{% endfor %} 

虽然这比返回预期的结果更多。

所以我基本上想要得到支持项目的支持者总数。

回答

4

我不知道你和重新组合做什么,但数最多支持者的项目是:

Project.objects.annotate(Count('backer')).latest('backer__count') 

使用注释 http://docs.djangoproject.com/en/dev/topics/db/aggregation/

如果你想在10个最已备份项目,这将是

Project.objects.annotate(Count('backer')).order_by('-backer__count')[:10] 

更新:我看到您可能的意思是“数量”,如在字段Backer.amount中,在这种情况下,您将修改查询以使用django.db.models.Sum

Project.objects.annotate(amount = Sum('backer__amount')).order_by('-amount')[:10]