簡單寫一下多對多查詢
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.uj5u.com/houduan/185245.html
標籤:Python
下一篇:Nginx 【介紹】
