prefetch_related和select_related的区别

参考链接:https://www.kancloud.cn/sindwerra/django/611518

个人理解

  • 1 多对一关系中,请在多的一方使用select_related(),在"一"的一方使用该方法会报错,如果实在想要在"一"的一方去获取多,情使用prefetch_related()方法
  • 2 多对一的关系中,多的一方不但可以使用select_related(),也可以使用prefetch_related(),但是前者效率高于后者
  • 3 对于多对多的关系,只能使用prefetch_related,而不能使用select_related,否则报错
  • 原理:select_related是在外键关联的对象确定只有一个的情况下才能使用,prefetch_related则不管外键关联的对象有几个,全部可以使用,因为它取的是一个集合(多对一时,多的一方外键仅关联一个对象;而多对多时,任何一方外键都关联多个对象,这刚好验证了个人理解的1,2,3)
  • 简单记忆:在关联的外键可能指向多个数据对象时,prefetch_related是唯一选择,而在外键指向的是一个唯一对象时,select_related方法明显要比prefetch_related高效,虽然prefetch_related也能用
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值