DRF-CreateAPIView嵌套序列化器

时间:2019-02-23 10:44:49

标签: python django django-rest-framework drf-queryset

我有一个有趣的问题,希望得到专家的意见。

我有以下型号。

class A(models.Model):
    b = ForeignKey(B)
    c = ForeignKey(B)
    d = ForeignKey(B)

class B(models.Model):
    pass

class C(models.Model):
    pass

class D(models.Model):
    pass

以下是我的序列化器:

class ASearializer(serializers.Serializer):
    b = BSearializer()
    c = CSearializer()
    d = DSearializer()

    class Meta:
        model = A
        fields = ('b', 'c', 'd')

    def create(self, data):
        # I create the instance of A, B, C and D.
        return instance_of_A

class BSearializer(serializers.Serializer):
    class Meta:
        model = B
        fields = '__all__'

class CSearializer(serializers.Serializer):
    class Meta:
        model = C
        fields = '__all__'

class DSearializer(serializers.Serializer):
    class Meta:
        model = D
        fields = '__all__'

我的观点:-

class View(CreateAPIView):
    serializer_class = Aserializer
    queryset = A.object.all().select_related('b').select_related('c').select_related('d')

一切正常。请求和响应正常工作。

但是,触发的查询不是预期的方式。返回数据时,DRF会触发3个额外的查询来过滤B,C和D,从而忽略了查询集。

1)如何使DRF触发一个单独的JOIN查询?

0 个答案:

没有答案