django 如何 prefetch_related 外建的 related_name

2019-11-11 17:48:27 +08:00
 kingofvir

django (a 模型)如何 prefetch_related 外建(b 模型)的 related_name (c 模型)


class A(models.Models):
	
    b = models.ForeignKey(B)
    
    
class B(models.Models):
	pass
    
    
class C(models.Models):
	b = models.ForeignKey(B, related_name='related_c')

如何在以下遍历时候,不逐次查询数据库


# 尝试过以下查询,依然逐次查询数据库

a_data = A.objects.prefetch_related('b__related_c')

for a in a_data:
	all_c_by_b = a.b.related_c.all()
    print(all_c_by_b.first())
3542 次点击
所在节点    Django
8 条回复
zzzmj
2019-11-11 19:14:01 +08:00
因为你用了.first() ,可以用 all_c_by_b[0] 试试
kingofvir
2019-11-12 09:45:10 +08:00
建议你自己试试先
kingofvir
2019-11-12 09:45:32 +08:00
@zzzmj 建议你试试先
zzzmj
2019-11-12 22:52:52 +08:00
ivamp
2019-11-12 23:00:50 +08:00
1 天 242 次点击就一个人回复你,其他 240 人估计都是自己试过,然后就没说话。。。。
zzzmj
2019-11-12 23:45:15 +08:00
@kingofvir 结果丢了个图床里,懒的试,链接总不会懒的点吧?
https://imgchr.com/i/M8wbEF
https://imgchr.com/i/M8wvg1
kingofvir
2019-11-18 18:14:44 +08:00
@zzzmj 首先对我的态度表示道歉,和对你贴图实际操作表示感谢。其实看了你的回答后我确实进行正式代码调整过,但是依然看到逐步的 sql 语句输出。现在想起,可能是因为类似的代码结构是 a --> a 序列化, b --> b 序列化,我可能调整了 a 和 b 的序列化,在刷新 a 对应的页面查看 sql 语句输出。

最终我修改为
```
a_data = A.objects.prefetch_related(
Prefetch('b__related_c', queryset=C.objects.all(), to_attr='all_c')
)
for a in a_data:
print(a.b.all_c[0].name_c)

```
kingofvir
2019-11-18 18:15:21 +08:00
@ivamp 感谢指正

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/618531

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX