首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >与django重组作斗争

与django重组作斗争
EN

Stack Overflow用户
提问于 2011-02-11 21:59:30
回答 1查看 663关注 0票数 0

我有两个模型。

一个项目和一个支持者模型。

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

重组是实现这一目标的唯一途径吗?

代码语言:javascript
运行
复制
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()

我尝试过以下几种方法:

代码语言:javascript
运行
复制
{% regroup backers by project as backers_list %}
{% for obj in backers_list %}
    <strong>{{ obj.grouper }}</strong><br />
{% endfor %}

尽管这会返回比预期更多的结果。

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

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-02-11 22:06:57

我不知道你在用regroup做什么,但拥有最多支持者的项目是:

代码语言:javascript
运行
复制
Project.objects.annotate(Count('backer')).latest('backer__count')

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

如果您想要获得最多支持的10个项目,它将是

代码语言:javascript
运行
复制
Project.objects.annotate(Count('backer')).order_by('-backer__count')[:10]

更新:我发现您的意思可能是Backer.amount字段中的"amount“,在这种情况下,您需要修改查询以使用django.db.models.Sum

代码语言:javascript
运行
复制
Project.objects.annotate(amount = Sum('backer__amount')).order_by('-amount')[:10]
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4969835

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档