Ale*_*erg 2 django django-orm django-queryset
我的模型看起来像:
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)
Run Code Online (Sandbox Code Playgroud)
我正在尝试运行这样的查询:
[[x.baz.a for x in y.page_set.all()]
for y in Book.objects.all().prefetch_related('page_set', 'page_set__baz')]
Run Code Online (Sandbox Code Playgroud)
我认为 ORM 应该能够执行两个查询: ( Page JOIN Baz
) 和Book
. 最后的连接应该在 Python 中进行。相反,我看到 ORM 执行了三个查询。我相信我必须知道如何使用select_related
,但这也不起作用(select_related
之前也没有移动prefetch_related
):
Book.objects.all().prefetch_related('page_set', 'page_set__baz').select_related('page_set__baz')
Run Code Online (Sandbox Code Playgroud)
查询(uploads
是应用程序):
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,)
Run Code Online (Sandbox Code Playgroud)
这与这里的评论有关:prefetch_related for multiple Levels
您可以尝试使用Prefetch
对象
from django.db.models import Prefetch
page_qs = Page.objects.select_related('baz')
books = Book.objects.prefetch_related(Prefetch('page_set', queryset=page_qs))
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
2899 次 |
最近记录: |