我想使用部分更新来更新模型的多对多字段。但是我得到了错误
<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).
任何建议我可能做错了什么以及如何解决此问题?
答案 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