Django:从相关的模型集中获取相关集

时间:2013-03-03 16:32:26

标签: python django foreign-keys database-relations

class Book(models.Model):
    # fields

class Chapter(models.Model):
     book = models.ForeignKey(Book)

class Page(models.Model):
     chapter = models.ForeignKey(Chapter)

我想要书A的所有页面,可能没有骑车每一章来获取页面。

book = Book.objects.get(pk=1)
pages = book.chapter_set.page_set #?!?

2 个答案:

答案 0 :(得分:4)

你不能这样做。 chapter_set是一个查询集,它没有属性page_set。

相反,转过来:

Page.objects.filter(chapter__book=my_book)

答案 1 :(得分:2)

查询交叉模型时,双下划线可能有帮助

book = Book.objects.get(pk=1)
pages = Page.objects.filter(chapter__book=book)