一、关联查询:
通过父表参数获取从表数据,通过从表参数获取父表数据
从表查询主表中的数据
附件:数据表截图
项目表
接口表
现在要实现的需求如下:
1、查询项目名称中包含’搜狗‘的所属接口信息:
分析:获取的是接口信息,所以Interfaces开头进行查询
2、查询项目负责人中包含’zilv‘的所属接口信息
分析:获取的是接口信息,所以Interfaces开头进行查询
主表查询从表中的数据
3、查询接口名称包含“收藏”所属的项目名称
分析:获取项目信息,所以Projects开头进行查询
查询格式为:
关联字段名称__关联模型类中的字段名称__查询类型
二、通过从表模型对象(已经获取到),如何获取父表数据
1、Interfaces.objects.filter(name__contains='收藏')[0].projects
2、可以通过外键字段先获取父表模型对象(interfaces_obj.projects)
interfaces_obj=Interfaces.objects.get(id=1)
三、通过父表模型对象(已经获取到),如何获取从表数据
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()
四、排序
可以使用QuerySet(manager对象).order_by('字段名1','字段名2','-字段名3')
默认为升序asc,可以在字段名称前添加“-”,那么为desc降序
升序(默认为升序)
Projects.objects.filter(Q(name__contains='2') | Q(leader='kb')).order_by('name')
降序
Projects.objects.filter(Q(name__contains='2') | Q(leader='kb')).order_by('-name')
排序(降序、升序混合使用)
qs = Projects.objects.filter(Q(name__contains='2') | Q(leader='kb')).order_by('-name','leader')