1

我无法找到使用元素在多对多关系中使用次数的计数来注释查询集的方法。

class Profile(models.Model):
    [...]
    # Profile can have multiple roles
    roles = models.ManyToManyField('Role', blank=True)
    [...]

class Role(models.Model):
    company = models.ForeignKey(Company, on_delete=models.CASCADE)
    name = models.CharField(blank=True, max_length=30)
    description = models.CharField(blank=True, max_length=300)
    [...]   

例如,我将有 5 个角色:

  • 角色1
  • 角色2
  • 角色3
  • 角色4
  • 角色5

并分配了以下角色的 2 个配置文件:

  • 简介1
    • 角色 1
    • 角色 2
  • 简介2
    • 角色 1
    • 角色 3
    • 角色 4

我想查询角色模型并使用具有该角色的配置文件数量进行注释。

所以返回一个查询集,如

Role1: company, name, description, profile_count=2
Role2: company, name, description, profile_count=1

ETC...

我已经尝试过了,但它不起作用:

Role.objects.annotate(profile_count=Count('profile__roles'))

它似乎返回一个总体计数,而不是每个角色的计数。

知道这是否可以在 Django 中本地完成,或者是否需要原始 SQL 请求?

谢谢!

4

1 回答 1

2

如果我正确理解你,你只想要这个:

Role.objects.annotate(profile_count=Count('profile'))

这几乎是你写的。

于 2018-10-10T06:19:39.480 回答