У меня есть следующая модель:
models.py:
class Host(models.Model):
serialnr = models.IntegerField(primary_key=True)
...some other fields...
class Event(models.Model):
id = models.AutoField(primary_key=True)
hosts = models.ManyToManyField(Host, through='EventHost')
...some other fields...
class EventHost(models.Model):
serialnr = models.ForeignKey(Host, on_delete=models.PROTECT)
event = models.ForeignKey(Event, on_delete=models.CASCADE)
...some other fields...
class Meta:
unique_together = ("serialnr", "event")
serializers.py:
class EventSerializer(serializers.ModelSerializer):
class Meta:
model = Event
fields = '__all__'
class HostSerializer(serializers.ModelSerializer):
class Meta:
model = Host
fields = '__all__'
class EventHostSerializer(serializers.ModelSerializer):
event = EventSerializer(read_only=True)
serialnr = HostSerializer(read_only=True)
class Meta:
model = EventHost
fields = '__all__'
views.py
class EventViewSet(viewsets.ModelViewSet):
queryset = Event.objects.order_by('-date')
serializer_class = EventSerializer
class HostViewSet(viewsets.ModelViewSet):
queryset = Host.objects.order_by('-serialnr')
serializer_class = HostSerializer
class EventHostViewSet(viewsets.ModelViewSet):
queryset = EventHost.objects.order_by('-start_date')
serializer_class = EventHostSerializer
Я отправляю следующее JSON с HTTP POST:
{event: {id: 4}, serialnr: {serialnr: 1234}, other_filed: 20}
, но это не event_id и serialnr_id не десериализованы, как видно из журнала:
psycopg2.errors.NotNullViolation: null value in column "event_id" violates not-null constraint
DETAIL: Failing row contains (12, 20, null, null).
I может читать данные с помощью HTTP GET, но не может писать с помощью POST. Как мне создать правильный сериализатор, чтобы он работал?
Также, когда я пытался отправить JSON, как показано ниже, он не работает:
{event_id: 4, serialnr_id: 1234, other_filed: 20}