当序列化的时候如果
只有data调用save()会走create()操作
有instanct和data 调用updata()操作
view.py
from rest_framework.views import APIView
from sers.models import Book
from rest_framework import serializers
from rest_framework.response import Response
# 针对模型设计序列化器 ----查询数据库数据赋值到这个类然后扔出去
# (我把数据转成json给前端发叫序列化)
class BookSerializers(serializers.Serializer):
id=serializers.IntegerField(read_only=True)#在客户端提交数据【反序列化阶段不会要求有id字段】 可以不传
title = serializers.CharField(max_length=8)
price = serializers.IntegerField(required=False) #required=True=反序列化阶段非必填)
# 左边date是给出去的字段,右边soure是具体数据模型对应取值的字段
date = serializers.CharField(source="pub_date")
# ======把操作独立出来意义在于解耦======== 当调用save()的时候源码create()方法是空的所以要重写
def create(self, validated_data):
# 添加数据逻辑
return Book.objects.create(**self.validated_data)
#当调用save()的时候,源码判断到有传instance的值,走update的方法,update的方法为空,
# 所以要重写,源码里已做了instance重新赋值更新后的数据,所有返回的是更新后的信息
def update(self, instance, validated_data):
# 更新逻辑
Book.objects.filter(pk=instance.pk).update(**self.validated_data)
uodated_book=Book.objects.get(pk=instance.pk)
return uodated_book
class BooketailView(APIView):
def put(self,request,id):
# 获取提交的更新数据
print(f"提交的数据:{request.data}")
update_book=Book.objects.get(pk=id)
#构建序列化器对象 # instance放原来的信息,data放要修改成的信息
# serializer.data是拿instance传的参数做序列化,
# 所以要加下面serializer.instance=Book.objects.get(pk=id)
# 赋值最新的数据到instance,serializer.data返回的才是更新的信息
# 个人认为下面不加instance就可以了,一样能返回更新的数据,但是没有展示id
serializer = BookSerializers(instance=update_book,data=request.data, many=False)
if serializer.is_valid():
# 更新操作
serializer.save()
return Response(f"更新成功{serializer.data}")
else:
return Response(f"更新失败: {serializer.errors}")
标签:序列化,更新,instance,save,data,serializer,drf From: https://www.cnblogs.com/kaibindirver/p/16806281.html