ORM多表查询——关联查询

在人生的道路上,不管是潇洒走一回,或者是千山独行,皆须是自己想走的路,虽然,有的人并不是很快就能找到自己的方向和道路,不过,只要坚持到底,我相信,就一定可以找到自己的路,只要找到路,就不必怕路途遥远了。

导读:本篇文章讲解 ORM多表查询——关联查询,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

一、关联查询:

通过父表参数获取从表数据,通过从表参数获取父表数据

从表查询主表中的数据

附件:数据表截图

项目表

ORM多表查询——关联查询 接口表ORM多表查询——关联查询

 现在要实现的需求如下:

1、查询项目名称中包含’搜狗‘的所属接口信息:

分析:获取的是接口信息,所以Interfaces开头进行查询

ORM多表查询——关联查询

 2、查询项目负责人中包含’zilv‘的所属接口信息

分析:获取的是接口信息,所以Interfaces开头进行查询

ORM多表查询——关联查询

主表查询从表中的数据

3、查询接口名称包含“收藏”所属的项目名称

分析:获取项目信息,所以Projects开头进行查询

ORM多表查询——关联查询

 查询格式为:

关联字段名称__关联模型类中的字段名称__查询类型

二、通过从表模型对象(已经获取到),如何获取父表数据

1、Interfaces.objects.filter(name__contains='收藏')[0].projects

  2、可以通过外键字段先获取父表模型对象(interfaces_obj.projects)

interfaces_obj=Interfaces.objects.get(id=1)

interfaces_obj.projects.name

ORM多表查询——关联查询

三、通过父表模型对象(已经获取到),如何获取从表数据

1、Projects.objects.filter(name__contains='搜狗')[0].interfaces.all()

 2、projects_obj=Projects.objects.get(id=1)

projects_obj.interfaces_set.all()

默认可以通过从表模型类名小写_set,返回manager对象,可以进一步使用filter进行过滤

如果在从表模型类的外键字段指定了related_name参数,那么会使用related_name指定参数作为名称

projects_obj=Projects.objects.get(id=1)

projects_obj.interfaces.all()

ORM多表查询——关联查询

四、排序

可以使用QuerySet(manager对象).order_by(‘字段名1′,’字段名2′,’-字段名3′)

默认为升序asc,可以在字段名称前添加“-”,那么为desc降序

升序(默认为升序)

Projects.objects.filter(Q(name__contains='2') | Q(leader='kb')).order_by('name')

ORM多表查询——关联查询

降序

Projects.objects.filter(Q(name__contains='2') | Q(leader='kb')).order_by('-name')

ORM多表查询——关联查询

 排序(降序、升序混合使用)

qs = Projects.objects.filter(Q(name__contains='2') | Q(leader='kb')).order_by('-name','leader')

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/123650.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!