Django订购的人数最多

时间:2016-01-30 01:59:22

标签: python django

我试图创建一个人们可以看到评价最高的文章的页面,有一个问题:当我过滤其他用户也喜欢的文章的喜欢数量时,它会创建一个副本赞成文章。

enter image description here

我想要的是以最多的喜欢来订购博客的文章。

models.py

class Article(models.Model):
    user = models.ForeignKey(User, default='1')
    [... unrelated fields ...]
    likes = models.ManyToManyField(User, related_name="likes")

    [... unrelated function ...]

views.py

def article_ordered_by_likes(request):
    context = {'article': Article.objects.order_by('-likes')}
    return render(request, 'article_ordered_by_likes.html', context)

def like_button(request):
    if request.method == 'POST':
        user = request.user
        id = request.POST.get('pk', None)

        article = get_object_or_404(Article, pk=id)

        if article.likes.filter(id=user.id).exists():
            article.likes.remove(user)
        else:
            article.likes.add(user)

        context = {'likes_count': article.total_likes}
    return HttpResponse(json.dumps(context), content_type='application/json')

article_ordered_by_likes.html

{% for a in article %}
    [... unrelated html ...]
    <h2>{{ a.titre }}</h2>
    <span id="count{{ a.id }}">{{ a.total_likes }}</span>
    <input type="button" class="like" id="{{ a.id }}" value="Like" />
{% endfor %}

为什么Django多次创建相同的帖子?如何在没有此问题的情况下以最多的喜欢订购文章?

2 个答案:

答案 0 :(得分:3)

Django没有创建多个帖子。它是因为那个查询。 如果你想根据类似的数量进行排序,那么你应该这样做,

Article.objects.annotate(like_count=Count('likes')).order_by('-like_count')

答案 1 :(得分:0)

您需要使用annotate。以下是您可以按照&#34;喜欢&#34;的用户数量订购的方式。一篇文章:

Article.objects.annotate(like_count=Count('likes')).order_by('-like_count')