zmdComeOn

django-blog:多对多查询

简单写一下多对多查询
model 不是多对多的字段我就没写上来的

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进行相关推荐 该如何查询

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 的一个列表
在这个列表内的都可以

如何要查询某个tag的id,中所有的文章思路应该也是一样的

post = Post.objects.filter(tag__id=tag.id)
 
 

分类:

技术点:

相关文章:

  • 2021-12-02
  • 2022-01-13
  • 2021-11-11
  • 2021-11-17
  • 2022-01-01
  • 2021-11-01
  • 2022-03-02
  • 2021-08-01
猜你喜欢
  • 2021-12-12
  • 2022-02-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-06-14
相关资源
相似解决方案