美文网首页django-blog
django-blog:多对多查询

django-blog:多对多查询

作者: 你常不走的路 | 来源:发表于2018-03-09 13:56 被阅读4次

简单写一下多对多查询
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)

相关文章

  • django-blog:多对多查询

    简单写一下多对多查询model 不是多对多的字段我就没写上来的 在编写view时 我需要 查出 某一篇文章 ...

  • 高级映射-一对多查询-多对多查询

    一 一对多查询-概述 1 需求 查询订单及订单明细 2 sql语句: 确定主查询表:订单表 orders 确定关...

  • Django-关系映射

    关系映射 一对一映射 语法 查询 一对多映射 语法 查询 多对多映射 语法 查询 自定义查询对象

  • SpringBoot+Spring JPA基础使用

    Spring JPA集成基础查询实例复杂查询+分页一对多查询及多对多查询 1. Spring JPA集成 1.1 ...

  • Django 原生多对多查询

    拿到所有的数据库分类

  • MyBatis联合查询(多对多)

    sql.txt 一个学生可以有多个老师授课,一个老师也可以带多个学生(多对多 需要一张中间表 tea_stu...

  • 高级映射-多对多查询

    1.需求查询用户及用户购买商品信息 2.思路 将用户信息映射到user中。 在UserBean类中添加订单列表属性...

  • mysql ---多对多

    flask的orm框架(SQLAlchemy)-一对多查询以及多对多查询(venv) $ pip install...

  • 关系的种类对于性能的影响

    一对多单向只有一个查询: 一对一双向同样只有一个查询: 多对一(维表为多端)双向,4个查询: 多对多双向,5个查询...

  • MyBatis7-一对多查询&对多对查询

    一对一查询 多对多查询 是不是看起来有点复杂了,但是很有条理,一步步的深入即可,仔细看看,其实不是很复杂,就是有点...

网友评论

    本文标题:django-blog:多对多查询

    本文链接:https://www.haomeiwen.com/subject/yompfftx.html