V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
kingofvir
V2EX  ›  Django

django 如何 prefetch_related 外建的 related_name

  •  
  •   kingofvir · 2019-11-11 17:48:27 +08:00 · 3539 次点击
    这是一个创建于 1838 天前的主题,其中的信息可能已经有所发展或是发生改变。

    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())
    
    8 条回复    2019-11-18 18:15:21 +08:00
    zzzmj
        1
    zzzmj  
       2019-11-11 19:14:01 +08:00
    因为你用了.first() ,可以用 all_c_by_b[0] 试试
    kingofvir
        2
    kingofvir  
    OP
       2019-11-12 09:45:10 +08:00
    建议你自己试试先
    kingofvir
        3
    kingofvir  
    OP
       2019-11-12 09:45:32 +08:00
    @zzzmj 建议你试试先
    zzzmj
        4
    zzzmj  
       2019-11-12 22:52:52 +08:00
    ivamp
        5
    ivamp  
       2019-11-12 23:00:50 +08:00
    1 天 242 次点击就一个人回复你,其他 240 人估计都是自己试过,然后就没说话。。。。
    zzzmj
        6
    zzzmj  
       2019-11-12 23:45:15 +08:00
    @kingofvir 结果丢了个图床里,懒的试,链接总不会懒的点吧?
    https://imgchr.com/i/M8wbEF
    https://imgchr.com/i/M8wvg1
    kingofvir
        7
    kingofvir  
    OP
       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
        8
    kingofvir  
    OP
       2019-11-18 18:15:21 +08:00
    @ivamp 感谢指正
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   4506 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 10:00 · PVG 18:00 · LAX 02:00 · JFK 05:00
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.