django-blog:多對多查詢

簡單寫一下多對多查詢
model 不是多對多的字段我就沒寫上來的html

class Tag(models.Model):
    name = models.CharField(max_length=20,verbose_name='標籤')
    add_time = models.DateField(default=datetime.now)

    class Meta:
        verbose_name = '標籤'
        verbose_name_plural = verbose_name

    def __str__(self):
        return self.name

class Post(models.Model):
    tag = models.ManyToManyField(Tag,verbose_name="標籤",null=True,blank=True,related_name='tags')
    add_time = models.DateField(default=datetime.now)

    class Meta:
        verbose_name = "文章"
        verbose_name_plural = verbose_name

    def __str__(self):
        return self.name

  在編寫view時 我須要 查出 某一篇文章 他所擁有的tags 和而後利用這些tags進行相關推薦 該如何查詢post

class ArticleView(View):
    def get(self, request, post_id):
        post = Post.objects.get(id=post_id)
        #獲取該post全部tags
        all_tags = post.tag.all()
        #獲取該tags全部的id
        all_tags_id = [tag.id for tag in all_tags]
        #查詢全部文章中有這些tags的文章 
        tag_post = Post.objects.filter(tag__id__in=all_tags_id)[:5]
        return render(request, 'article.html', {
            'post': post,
            'all_tags':all_tags,
            'tag_post':tag_post
        })

  

最主要的 就是 先獲取到 該文章擁有的tags
而後利用列表解析式 來 獲取全部的tags的id
而後 在到 Post這個model中去查詢
這裏查詢用到的 tag__id__in 就是 查詢 tag外鍵的id 的一個列表
在這個列表內的均可以htm

如何要查詢某個tag的id,中全部的文章思路應該也是同樣的blog

post = Post.objects.filter(tag__id=tag.id)
相關文章
相關標籤/搜索