Django REST框架外键 - NOT NULL约束失败

时间:2016-07-26 16:12:07

标签: python django django-models django-rest-framework

我在Django REST Framework中有以下设置:

models.py:

class Device(models.Model):
    name = models.CharField()
    latitude = models.FloatField()
    longitude = models.FloatField()
    altitude = models.FloatField()

class Event(models.Model):
    id_device = models.ForeignKey(Device, related_name='events')
    name = models.CharField()
    date = models.CharField()
    time = models.CharField()

class Values(models.Model):
    id_device = models.ForeignKey(Device)
    id_event = models.ForeignKey(Event, related_name='values')
    x = models.FloatField()
    y = models.FloatField()
    z = models.FloatField()
    time = models.IntegerField()

serializers.py:

class DeviceSerializer(serializers.ModelSerializer):    

    events = EventSerializer(many=True)

    class Meta:
        model = Device
        fields = ('url', 'id', 'name', 'latitude', 'longitude', 'altitude', 'events')

    def create(self, validated_data):
        events_data = validated_data.pop('events')
        device = Device.objects.create(**validated_data)
        for event in events_data:
            Events.objects.create(device=device, **event)
        return device

class EventSerializer(serializers.ModelSerializer):

    values = ValuesSerializer(many=True)

    class Meta:
        model = Event
        fields = ('url', 'id', 'name', 'date', 'time', 'values')

    def create(self, validated_data):
        values_data = validated_data.pop('values')
        event = Event.objects.create(**validated_data)
        for value in values_data:
            Values.objects.create(event=event, **value)
        return event

class ValuesSerializer(serializers.ModelSerializer):
    class Meta:
        model = Values
        fields = ('x', 'y', 'z', 'time')

当我尝试发布事件时,使用像这样的JSON文件分配了一些

{
    "name": "name_example", 
    "date": "date_example", 
    "time": "time_example", 
    "values": [
      {
        "x": 1, 
        "y": 2, 
        "z": 3, 
        "time": 1
      }, 
      {
        "x": 10, 
        "y": 20, 
        "z": 30, 
        "time": 2
      }, 
      {
        "x": 100, 
        "y": 200, 
        "z": 300, 
        "time": 4
      }
   ]
}

我收到错误IntegrityError: NOT NULL constraint failed: drf_event.id_device_id

我是这个框架的新手,所以如何发布新的事件,并将分配给现有设备

1 个答案:

答案 0 :(得分:2)

您还没有指向EventSerializer中设备的键。你错过了id_device。

class EventSerializer(serializers.ModelSerializer):

    values = ValuesSerializer(many=True)

    class Meta:
        model = Event
        fields = ('id_device', 'url', 'id', 'name', 'date', 'time', 'values')

你需要在你的json中添加密钥:

{
    "id_device": 1,
    "name": "name_example", 
    "date": "date_example", 
    "time": "time_example", 
    "values": [
      {
        "x": 1, 
        "y": 2, 
        "z": 3, 
        "time": 1
      }, 
      {
        "x": 10, 
        "y": 20, 
        "z": 30, 
        "time": 2
      }, 
      {
        "x": 100, 
        "y": 200, 
        "z": 300, 
        "time": 4
      }
   ]
}