2014-11-25 1 views
0

내 모델 보이는select_related 후 prefetch_related

나는 ORM 두 개의 쿼리로 수행 할 수 있어야한다고 생각
[[x.baz.a for x in y.page_set.all()] 
for y in Book.objects.all().prefetch_related('page_set', 'page_set__baz')] 

: (Page JOIN Baz) 및 Book. 최종 결합은 Python에서 이루어져야합니다. 대신 ORM이 세 가지 쿼리를 실행하는 것을 봅니다. 나는 select_related을 사용하는 방법 몇 가지를 가지고 있다고 생각하지만,이 작동 중 하나를하지 않습니다 (도 prefetch_related 전에 select_related 이동 않음) :

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

쿼리 (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,) 

이를 여기에 주석 관련이있다 : prefetch_related for multiple Levels

답변

2

당신이 사용하려고 할 수 Prefetch object

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