Получить набор запросов из другой модели в наборе запросов в Django
class V(models.Model):
title = models.CharField(max_length=100, blank=True, default='')
doc = models.ForeignKey(D, on_delete=models.CASCADE, default='')
upload_time = models.DateTimeField(auto_now_add=True)
class Meta:
ordering = ('upload_time',)
class D(models.Model):
name = models.CharField(max_length=100, blank=True, default='')
def __str__(self):
return self.name
в ModelViewSet я написал так:
class index(viewsets.ModelViewSet):
serializer_class = VSerializer
queryset = V.objects.all()
Я получил эти данные через API
{
"id": 1,
"title": xxxxx
"d_id": 8,
...
...
}
Тем не менее, я хочу, чтобы d_id был более конкретным, например:
{
"id": 1,
"title": xxxxx
"d_id": {
"id": 8,
"name": xxx,
....
}
...
...
}
Таким образом, данные в D-модели были получены через d_id=8 и прикреплены к исходному набору запросов.
Как я мог это сделать? Нужна ваша помощь...
1 ответ
Решение
Создайте сериализатор для вашей модели D.
class DSerializer(serializers.ModelSerializer):
class Meta:
model = D
fields = ('field_1', 'field_2', 'field_3')
И в вашем VSerializer добавьте поле сериализатора следующим образом:
class VSerializer(serializers.ModelSerializer):
d = DSerializer() # This will add D's fields in V's API.
class Meta:
model = V
fields = ('field_1', 'field_2', 'field_3')
Прочитайте эту документацию для получения более подробной информации. http://www.django-rest-framework.org/api-guide/relations/
Надеюсь это поможет.