django - 预取相关之后选择相关

标签 django django-queryset django-orm

我的模型看起来像:

class Book(models.Model):
    publisher = models.ForeignKey(Publisher) # This is not important

class Baz(models.Model):
    a = models.CharField(max_length=100)

class Page(models.Model):
    book = models.ForeignKey(Book)
    baz = models.ForeignKey(Baz)

我正在尝试运行这样的查询:

[[x.baz.a for x in y.page_set.all()]
for y in Book.objects.all().prefetch_related('page_set', 'page_set__baz')]

我认为 ORM 应该能够执行两个查询:(Page JOIN Baz) 和 Book。最终连接应在 Python 中进行。相反,我看到 ORM 执行三个查询。我相信我必须知道如何使用 select_lated,但这也不起作用(在 prefetch_lated 之前移动 select_lated 也不起作用):

Book.objects.all().prefetch_related('page_set', 'page_set__baz').select_related('page_set__baz')

查询(上传是应用程序):

QUERY = u'SELECT "uploads_book"."id", "uploads_book"."publisher_id" FROM "uploads_book"' - PARAMS = (); args=()
QUERY = u'SELECT "uploads_page"."id", "uploads_page"."book_id", "uploads_page"."baz_id" FROM "uploads_page" WHERE "uploads_page"."book_id" IN (%s, %s)' - PARAMS = (1, 2); args=(1, 2)
QUERY = u'SELECT "uploads_baz"."id", "uploads_baz"."a" FROM "uploads_baz" WHERE "uploads_baz"."id" IN (%s)' - PARAMS = (1,); args=(1,)

这与此处的评论相关:prefetch_related for multiple Levels

最佳答案

您可以尝试使用Prefetch object

from django.db.models import Prefetch

page_qs = Page.objects.select_related('baz')
books = Book.objects.prefetch_related(Prefetch('page_set', queryset=page_qs))

关于django - 预取相关之后选择相关,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27121331/

相关文章:

python - 如何在 tastypie django 中记录所有请求

sql - Django annotate() 多次导致错误答案

django - 在 Django 中过滤 prefetch_related 为空

json - 使用 django query set values() 索引到 JSONField

python - Django查询集过滤列表的最大值

django - Django ManyToMany 字段的 set() 操作是否清除现有关系?

python - 在 Django 中获取当前日期(和时间)

python - Django 模型中 int() 的文字无效

python - 如何为 TestCase 设置一次 "return_value"。 Python。 Django

python - 动态创建周期性任务