Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/360.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 访问嵌套的foreignkey对象的正确方法?_Python_Django_Foreign Keys - Fatal编程技术网

Python 访问嵌套的foreignkey对象的正确方法?

Python 访问嵌套的foreignkey对象的正确方法?,python,django,foreign-keys,Python,Django,Foreign Keys,我有具有层次关系的模型: class School(models.Model): name = models.CharField() class Class(models.Model): school = models.ForeignKey(School) class Student(models.Model): class = models.ForeignKey(Class) 我想检索每个学生与特定学校相关的对象 我通常是这样做的: the_school = Sc

我有具有层次关系的模型:

class School(models.Model):
    name = models.CharField()

class Class(models.Model):
    school = models.ForeignKey(School)

class Student(models.Model):
    class = models.ForeignKey(Class)
我想检索每个
学生
与特定
学校
相关的对象
我通常是这样做的:

the_school = School.objects.get(name='Springfield Elementary School')
students = Student.objects.filter(class__school=the_school)
但是这种方法需要两个模型来查找(
学校
学生
),这似乎有些不必要。。。对我来说。
因此,我尝试使用Django内置的相关管理器进行单行查询:

students = School.objects.get(name='...').class_set.student_set.all()
# or 
students = School.objects.get(name='...').class_set.all().student_set.all()
…这不起作用

如何从给定的
School
object向下引用查询?

或者有更好的解决方案吗?

您可以使用
class\uuuuu school\uuu name
作为筛选参数:

students = Student.objects.filter(class__school__name='Springfield Elementary School''Springfield Elementary School')

正如Nevervoner在他的回答中所显示的,诀窍是从你想要的课程开始——也就是说,学生。