Я пытаюсь получить тот же вывод, что и мой django запрос, но фактический вывод отличается, когда Django Rest Framework его обслуживает. Добавил следующее в мой сериализатор, но оно не учитывало cart_assessments__risk_type
из вывода. Как сделать так, чтобы вывод сериализатора django rest Framework соответствовал выводу моего запроса django?
models.py:
from django.db import models
class TrainAssessment(models.Model):
train_name = models.CharField(max_length=30)
class CartAssessment(models.Model):
train_assessment = models.ForeignKey(TrainAssessment, on_delete=models.CASCADE, related_name='cart_assessments')
risk_type = models.CharField(max_length=30)
views.py
from rest_framework import viewsets, mixins
class SubwayTrainDetailsViewSet(viewsets.GenericViewSet,
mixins.ListModelMixin,
mixins.CreateModelMixin):
queryset = TrainAssessment.objects.values('cart_assessments__risk_type').annotate(
cart_count=Count('cart_assessments__risk_type')).order_by('-cart_count').annotate(
train_count=Count('id', distinct=True))
serializer_class = serializers.SubwayTrainDetailsViewSetSerializer
serializers.py
from rest_framework import serializers
class SubwayTrainDetailsViewSetSerializer(serializers.ModelSerializer):
train_count = serializers.IntegerField()
cart_count = serializers.IntegerField()
cart_assessments__risk_type = serializers.RelatedField(source="cartassessment.risk_type", read_only=True)
class Meta:
model = TrainAssessment
fields = ('id', 'cart_assessments__risk_type', 'train_count', 'cart_count')
Я пытаюсь заставить мой сериализатор выдавать такой же вывод, как показано ниже:
#QUERY
queryset = TrainAssessment.objects.values('cart_assessments__risk_type').annotate(
cart_count=Count('cart_assessments__risk_type')).order_by('-cart_count').annotate(
train_count=Count('id', distinct=True))
#OUTPUT I WANT THAT COMES FROM ABOVE QUERY:
{'cart_assessments__risk_type': '', 'cart_count': 55, 'train_count': 14}
{'cart_assessments__risk_type': 'door', 'cart_count': 22, 'train_count': 13}
{'cart_assessments__risk_type': 'wheel', 'cart_count': 8, 'train_count': 8}
{'cart_assessments__risk_type': 'frame', 'cart_count': 1, 'train_count': 1}
{'cart_assessments__risk_type': 'floors', 'cart_count': 1, 'train_count': 1}
{'cart_assessments__risk_type': 'windows', 'cart_count': 1, 'train_count': 1}
{'cart_assessments__risk_type': 'straphanger', 'cart_count': 1, 'train_count': 1}
Фактический вывод отсутствует cart_assessments__risk_type
из Django Rest Framework при нажатии на конечная точка / маршрут для SubwayTrainDetailsViewSet:
# OUTPUT MISSING `cart_assessments__risk_type`
[
{"train_count": 14, "cart_count": 55},
{"train_count": 13, "cart_count": 22},
{"train_count": 8, "cart_count": 8},
{"train_count": 1, "cart_count": 1},
{"train_count": 1, "cart_count": 1},
{"train_count": 1, "cart_count": 1},
{"train_count": 1,"cart_count": 1}
]
Как я django остальная структура может обслуживать вывод с cart_assessments__risk_type
? p