通过自定义管理器计算对给定内容类型的评论

时间:2013-01-02 14:06:47

标签: python django

我试图为模型的查询集注释一个注释计数。

我可以像这样做一个,它可以工作:

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')

0 个答案:

没有答案