(1)针对当前帖子检索全部标签
(2)获取包含特定标签的帖子
(3)从结果列表中排除当前帖子
(4)通过当前帖子的标签号,对结果进行排序
(5)如果具有相同标签号的两个或多个帖子,推荐使用最近发布的帖子
(6)将查询限制为希望推荐的帖子数量
引入Count聚合(views.py)
聚合函数还包括Avg,Max,Min等
from django.db.models import Count
#list of similar posts
post_tags_ids = post.tags.values_list('id', flat=True)
similar_posts = Post.published.filter(tags__in=post_tags_ids).exclude(id=post.id)
similar_posts = similar_posts.annotate(same_tags=Count('tags')).order_by('-same_tags','-publish')[:4]
return render(request, 'blog/post/detail.html',
{'post': post,
'comments': comments,
'new_comments': new_comment,
'comments_form': comments_form,
'similar_posts': similar_posts})
1.针对当前帖子的标签,检索ID列表。value_list()QuerySet返回给点字段的元组
2.获取包含此类标签的全部帖子并排除当前帖子本身
3.使用Count生成一个计算后的字段
4.降序排列且显示最新的四个帖子
编辑detail.html模板
在帖子评论列表前添加如下代码
<h2>Similar posts</h2>
{% for post in similar_posts%}
<p>
<a href="{{ post.get_absolute_url }}">{{ post.title }}</a>
</p>
{% empty %}
There are no similar posts yet.
{% endfor %}