我有两个宽泛定义如下的模型:
class InformationUnit(models.Model):
username = models.CharField(max_length=255)
project = models.ForeignKey('Project')
...
class Project(models.Model):
name = models.CharField(max_length=255)
现在,在一个视图中,我想对属于一个项目的所有 InformationUnit
进行注释,所以我这样做:
p = Project.objects.all().annotate(Count('informationunit')
效果还不错。
此外,我想知道,在每个项目中,有多少不同的 username
参与。
也就是说,计算组成一个项目的 InformationUnit
中有多少不同的 username
。
我尝试了以下方法,但它只是计算 InformationUnit
的数量,而不考虑 username
:
p = Project.objects.all().annotate(Count('informationunit__username')
请注意,username
不是一个对象,它是一个字符串。有没有一种简洁的方法来做到这一点,或者我应该创建一个更复杂的基于循环和意大利面条代码的代码: P
非常感谢!