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)
作者:子钦加油
出处:https://www.cnblogs.com/zmdComeOn/
个性签名:努力生活,努力走路
阿里云拼团:https://www.aliyun.com/1111/home?userCode=f4ee1llo1核2G1M,86一年,229三年;2核4G5M,799三年;2核8G5M,1399三年
腾讯云三月采购计划特价:https://cloud.tencent.com/act/cps/redirect?redirect=1073&cps_key=15d0b1673287c43fe946626d9f4e2eee&from=console1核2G1M,88一年;1核2G1M,268三年;2核4G5M,998一年;4核8G5M,2888元三年
出处:https://www.cnblogs.com/zmdComeOn/
个性签名:努力生活,努力走路
阿里云拼团:https://www.aliyun.com/1111/home?userCode=f4ee1llo1核2G1M,86一年,229三年;2核4G5M,799三年;2核8G5M,1399三年
腾讯云三月采购计划特价:https://cloud.tencent.com/act/cps/redirect?redirect=1073&cps_key=15d0b1673287c43fe946626d9f4e2eee&from=console1核2G1M,88一年;1核2G1M,268三年;2核4G5M,998一年;4核8G5M,2888元三年