使用部分更新来更新模型的多对多字段-仅允许非关系和外键

时间:2018-07-05 03:44:43

标签: django-models django-rest-framework many-to-many

我想使用部分更新来更新模型的多对多字段。但是我得到了错误

<django.db.models.fields.related.ManyToManyField: skills> (only non-relations and foreign keys permitted).

这是我的模型当前的样子

class modelJob(models.Model):
    skills              = models.ManyToManyField(modelSkill,blank=True)
    title               = models.CharField(max_length=200, unique=False,blank=False,null=True)
    moreInfo            = models.CharField(max_length=500, unique=False,blank=False,null=True)

这是我的序列化器的样子

class Serializer_PartialUpdateJob_RX(serializers.ModelSerializer):
    class Meta:
        model = modelJob
        fields = '__all__'

    def update(self, instance, validated_data):
        modelJob.objects.filter(pk=instance.id).update(**validated_data)
        job = modelJob.objects.get(pk=instance.id)
        return job

这就是我的看法

class PartialUpdate_Jobs(GenericAPIView, UpdateModelMixin):
    queryset = modelJob.objects.all()
    serializer_class = Serializer_PartialUpdateJob_RX
    lookup_field = 'id'

    def put(self, request, *args, **kwargs):
        result =  self.partial_update(request, *args, **kwargs)
        return Response(Serializer_Job_TX(self.queryset[0]).data)

现在我只想更新很多字段(技能),这就是我的json的样子

{
    "skills" :[ 
               2,4
             ]
}

其中2和4是技能对象的ID,此时我得到了错误

<django.db.models.fields.related.ManyToManyField: skills> (only non-relations and foreign keys permitted).

任何建议我可能做错了什么以及如何解决此问题?

1 个答案:

答案 0 :(得分:2)

您可以在序列化程序的更新功能中完成此操作。

首先,您将“技能”介绍为序列化程序的属性,这是技能ID的列表。如果您想使用相同的序列化器列出,但是您选择的名称建议是“部分”序列化器,您可能会用别的名称命名。我假设它仅用于更新。

class Serializer_PartialUpdateJob_RX(serializers.ModelSerializer):
    skills = serializers.PrimaryKeyRelatedField(queryset=modelSkill.objects.all(), write_only=True, many=True, required=False)

    def update(self, instance, validated_data):
         skills = validated_data.pop('skills', None)
         instance = super().update(instance, validated_data) # if you want to update other fields

         # now update skills 
         if skills is not None:
             for skills in skills:
                 instance.skills.add(skill)
             instance.save()

         return instance