我在对多对多相关字段执行聚合查询时遇到问题。在
以下是我的模型:
class SortedTagManager(models.Manager):
use_for_related_fields = True
def get_query_set(self):
orig_query_set = super(SortedTagManager, self).get_query_set()
# FIXME `used` is wrongly counted
return orig_query_set.distinct().annotate(
used=models.Count('users')).order_by('-used')
class Tag(models.Model):
content = models.CharField(max_length=32, unique=True)
creator = models.ForeignKey(User, related_name='tags_i_created')
users = models.ManyToManyField(User, through='TaggedNote',
related_name='tags_i_used')
objects_sorted_by_used = SortedTagManager()
class TaggedNote(models.Model):
"""Association table of both (Tag , Note) and (Tag, User)"""
note = models.ForeignKey(Note) # Note is what's tagged in my app
tag = models.ForeignKey(Tag)
tagged_by = models.ForeignKey(User)
class Meta:
unique_together = (('note', 'tag'),)
但是,聚合字段used
的值只有在直接查询模型时才是正确的:
你能告诉我它怎么了吗?提前谢谢。在
我现在已经知道出了什么问题以及如何解决:)
在我的例子中,我应该确保
SortedTagManager
是第一个定义的Manager
。2.我应该计数
notes
而不是users
:相关问题 更多 >
编程相关推荐