欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Django实现一对多表模型的跨表查询方法

程序员文章站 2024-02-03 12:18:28
当有两个表,例如一个学生表,一个班级表,是多对一的关系。 方法1: c = models.class.object.get(pk=1) #查询到id为1的班级...

当有两个表,例如一个学生表,一个班级表,是多对一的关系。

方法1:

c = models.class.object.get(pk=1)
#查询到id为1的班级
stus = models.student.object.filter(cls=c)
# 查询出来所有班级为c的学生
#stus是多个对象
#可以循环出结果
for stu in stus :
 print stu.id,stu.name

方法2

stus = models.student.object.filter(cls__name='1703')
#双下划线为跨表查询,查询学生对应的所有cls为1703的学生

方法3

c=models.class.object.get(pk=1)
#获取id为1的班级
stus=c.student_set.all
#获取所有该班级下的所有学生

html页面获取方法

<td>{{ line.student_set.count }}</td>

以上这篇django实现一对多表模型的跨表查询方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。