【问题标题】:select_related queryset with ModelSerializer in Django rest framework在 Django rest 框架中使用 ModelSerializer 选择相关查询集
【发布时间】:2015-09-08 07:15:42
【问题描述】:

我正在尝试将“select_related”查询集方法与 DRF 序列化程序一起使用, 但是这个例子仍然在做很多 sql 查询。

如何从 select_related 方法中获取相关对象“model_b”?

class Model_A(models.Model):
    title = models.CharField(max_length=100)
    description = models.TextField()
    model_b = models.ForeignKey(Model_B, null=True, blank=True)

class Model_B(models.Model):
    title = models.CharField(max_length=100)


class Model_A_Serializer(serializers.ModelSerializer):
    model_b = Model_B_Serializer(source="model_b")
    class Meta:
        model = Model_A
        fields = ('title', 'model_b')

class Model_B_Serializer(serializers.ModelSerializer):
    class Meta:
        model = Model_B


class Model_A_View(viewsets.ModelViewSet):
    serializer_class = Model_A_Serializer
    queryset = Model_A.objects.select_related('model_b').all()

【问题讨论】:

  • 您的实际代码可能存在一些问题,但它应该可以正常工作,如上所述。我需要更多信息。
  • 我投票结束这个问题作为离题,因为你没有包括你得到的 SQL 查询。根据您编写的代码应该可以正常工作。

标签: django-rest-framework


【解决方案1】:

Use prefetch_related instead.

queryset = Model_A.objects.all().prefetch_related('model_b')

此外,您可以使用this answer 将您的 sql 查询记录到控制台

【讨论】:

  • prefetch_related 不是更好地应用于多对多关系吗?
  • 我在 ForeignKeys、ManyToMany 和推断的 other-model related_name 字段上使用它。在调试模式下,我打印出我所有的 sql 查询。当我使用prefetch_related 时,我在其他型号上的所有微小的单项请求都消失了。它只对具有大量 id 的相关 FK 模型进行一次查询。
  • select_related 在您的情况下应该可以正常工作它们的行为略有不同:select_related 将通过连接将 model_b 包含在原始查询中,prefetch_related 将使用 @ 为 model_b 运行一个单独的查询987654330@.
猜你喜欢
  • 2015-05-15
  • 2015-05-08
  • 2013-10-05
  • 1970-01-01
  • 2016-05-03
  • 2016-11-09
  • 2014-12-19
相关资源
最近更新 更多