我试图为模型的查询集注释一个注释计数。
我可以像这样做一个,它可以工作:
entry_type是内容类型对象。
popular_posts = Post.objects.all().annotate(\
comment_count=Sum("id")).extra(select={
'comment_count': """SELECT COUNT(*) FROM django_comments
WHERE django_comments.object_pk = Blogger_post.id
AND django_comments.content_type_id = %s"""
}, select_params=(entry_type.id,)).order_by('-comment_count')
然而,当我尝试
时popular_posts = Post.custom_manager.all()
#custom_manager
class PostManager(models.Manager):
def get_query_set(self):
return super(PostManager,self).get_query_set().all().annotate(\
comment_count=Sum("id")).extra(select={
'comment_count': """SELECT COUNT(*) FROM django_comments
WHERE django_comments.object_pk = Blogger_post.id
AND django_comments.content_type_id = %s"""
}, select_params=(entry_type.id,)).order_by('-comment_count')
有一个comment_count,但它不是预期值。
我做错了什么?
编辑: 我仍然不知道这个问题是什么,但这有效
class PostManager(models.Manager):
def get_query_set(self):
return super(PostManager,self).get_query_set().all().extra(select={
'comment_count': """SELECT COUNT(*) FROM django_comments
WHERE django_comments.object_pk = Blogger_post.id
AND django_comments.content_type_id = %s"""
}, select_params=(entry_type.id,)).order_by('-comment_count')