zoukankan      html  css  js  c++  java
  • 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)
    
     
     

  • 相关阅读:
    ActiveMQ消息队列的使用及应用
    kafka使用场景
    何时使用MQ ?
    activemq、rabbitmq、kafka原理和比较
    JAVA消息 AMQP
    JAVA消息 JMS 很重要
    ubuntu下如何安装linaro工具链?
    linux下如何将dts转换成dtb?
    linux设备树中如何删除某个节点?
    如何在uboot下列出使用的设备树信息?
  • 原文地址:https://www.cnblogs.com/zmdComeOn/p/12399042.html
Copyright © 2011-2022 走看看