Django prefetch_related 上 __str__() 方法

Posted

技术标签:

【中文标题】Django prefetch_related 上 __str__() 方法【英文标题】:Django prefetch_related on __str__() method 【发布时间】:2018-02-10 15:07:15 【问题描述】:

我的模型:

class B(models.Model):
    label = models.CharField()

class A(models.Model):
    b = models.OneToOneField(B, null=True, blank=True, on_delete=models.PROTECT)

    def __str__(self):
        return u'[] Event:'.format(self.b.label)

现在,使用 django 调试工具栏查看请求期间完成的查询,我注意到许多查询执行了 200 多次。我知道我会使用 prefetch_related 来解决,但是当在 str 方法中完成查找时,我必须把它放在哪里?

【问题讨论】:

不!不要把它放在__str__。请发布您的视图代码,这很可能是所有这些查询发生的地方 200+次是由可浏览API形式的选择引起的 好吧,我不认为这是可定制的。只要您的最终用户看不到该页面,就可以了。你应该优化自己的观点 【参考方案1】:

您的GenericViewModelViewSet 应该有一个queryset 属性来定义它应该在哪个集合上工作。

您需要在此处添加prefetch_related / select_related

class UserList(generics.ListCreateAPIView):
    queryset = User.objects.all().prefetch_related('groups')
    serializer_class = UserSerializer
    permission_classes = (IsAdminUser,)

【讨论】:

需要 all() 吗?

以上是关于Django prefetch_related 上 __str__() 方法的主要内容,如果未能解决你的问题,请参考以下文章

如何在 django rest 框架中的嵌套序列化器相关对象上使用 prefetch_related?

使用 prefetch_related 优化 Django Queryset 多对多 for 循环

django- 在另一个 prefetch_related 中使用 prefetch_related

Django中select_related和prefetch_related的用法与区别

Django中select_related和prefetch_related的用法与区别

Django:prefetch_related() 是不是遵循反向关系查找?