之前我们学习的都是处理书籍或者出版社的所有的数据的方法,下面我们来看下处理单个书籍,或者单个出版社的方法

这个时候我们就需要重新写一个类,这个类的方法,就需要有3个参数,参数1是self,参数2是request,参数3是id,因为我们是处理单条数据,所有必须要有一个id

首先我们先写一个类,这个类主要序列化我们的model对象或者queryset的类,这里我们不对一对多和多对多字段做特殊的显示处理,让他用默认值就好了,因为如果我们做特殊的处理,多对多字段在put请求和post请求的处理有点问题,我还是没有解决

我们的类就是这么简单,默认情况下,一对多字典会显示1表中的数据的id,多对多会显示多表中的id,但是会放在一个列表中

class bookmodelserializer(serializers.ModelSerializer):
class Meta:
model = models.Book
fields = "__all__"

  

如果我们想控制一对多和多对多显示的字段,我们可以用下面的方法来处理,但是这个时候我们就需要重写update方法和create方法

class bookmodelserializer(serializers.ModelSerializer):
class Meta:
model = models.Book
fields = "__all__" # 一对多字段,使用source控制显示的内容
book_publish = serializers.CharField(source="book_publish.publish_name") # 多对多字段,需要使用SerializerMethodField这个方法和get_book_auther这个函数配合来显示指定的信息,但是在更新和新建操作就会有问题
book_auther = serializers.SerializerMethodField()
def get_book_auther(self, obj):
s = []
for i in obj.book_auther.all():
s.append(i) return s

  

但是我们这里用默认的方法就好了,不对一对多和多对多字段做特殊的处理

下面的代码是具体的cbv中的class的代码

class Book_detail_cbv(APIView):
def get(self,request,id):
obj = models.Book.objects.filter(id=id).first() # bs = bookmodelserializer(obj,many=False,context={'request': request})
bs = bookmodelserializer(obj, many=False,)
return Response(bs.data) def put(self,request,id):
obj = models.Book.objects.filter(id=id).first()
bs = bookmodelserializer(obj,data=request.data)
if bs.is_valid():
bs.save() return Response(bs.data)
else:
return Response(bs.errors) def delete(self,request,id):
models.Book.objects.filter(id=id).delete()
return HttpResponse("删除成功")

  

首先看下get请求,就是为了获取单条数据

首先看下get函数,如果modelserializer类如果传递是一个queryset对象,则many=True,但是如果是一个model对象,则many=False或者可以不写,因为默认就是False

    def get(self,request,id):
obj = models.Book.objects.filter(id=id).first() # bs = bookmodelserializer(obj,many=False,context={'request': request})
bs = bookmodelserializer(obj, many=False,)
return Response(bs.data)

  

我们通过postman发送get请求的url,我们注意看,一对多和多对多的字段都是显示id

然后在看下put请求的函数,这里传递一个model对象和request.data进去,调用save方法就会帮我们更新数据库中的数据

    def put(self,request,id):
obj = models.Book.objects.filter(id=id).first()
bs = bookmodelserializer(obj,data=request.data)
if bs.is_valid():
bs.save() return Response(bs.data)
else:
return Response(bs.errors)

  

我们通过postman发送一个put请求,测试 一下,我们看到数据已经更新

最后我们在看下delete请求,这里我们就看下代码就可以了

    def delete(self,request,id):
models.Book.objects.filter(id=id).delete()
return HttpResponse("删除成功")

  

然后我们通过postman发送delete请求,测试删除的函数

我们再次get id为3的book就已经get不到了

至此单条数据的在序列化处理就完成了

Django的restframework的序列化组件之对单条数据的处理的更多相关文章

  1. RestFramework之序列化组件

    一.restframework的序列化组件的使用 1.导入序列化组件与模型类 from rest_framework import serializers from app01.models impo ...

  2. django自带的序列化组件

    1.什么是序列化组件 在django中,自带一个序列化组件,它是用来将数据进行整理.转化成特定的为一个特定的格式(比如json数据格式),然后传输给前端,以便前端对数据进行处理操作. 2.为什么要用序 ...

  3. rest-framework之序列化组件

    一:django自带序列化组件 Django内置的serializers(把对象序列化成json字符串) from django.core import serializers def test(re ...

  4. Django框架第九篇--Django和Ajax、序列化组件(serializers)、自定义分页器、模型表choice参数

    Django和Ajax 一.什么是Ajax AJAX(Asynchronous Javascript And XML)翻译成中文就是“异步的Javascript和XML”.即使用Javascript语 ...

  5. Django day26 HyperlinkedIdentityField,序列化组件的数据校验以及功能的(全局,局部)钩子函数,序列化组件的反序列化和保存

    一:HyperlinkedIdentityField(用的很少):传三个参数:第一个路由名字,用来反向解析,第二个参数是要反向解析的参数值,第三个参数:有名分组的名字 -1 publish = ser ...

  6. Django的rest_framework的序列化组件之序列化多表字段的方法

    首先,因为我们安装了restframework,所以我们需要在django的settings中引入restframework INSTALLED_APPS = [ 'django.contrib.ad ...

  7. Django的rest_framework的序列化组件之serializers.ModelSerializer介绍

    这里的介绍的serializers.ModelSerializer就和我们之前学习的modelform一样 serializers.ModelSerializer如下几个功能 1.序列化queryse ...

  8. rest-framework之APIView 序列化组件

    rest-framework之APIView 一 安装djangorestframework 方式一:pip3 install djangorestframework 方式二:pycharm图形化界面 ...

  9. Django 之restfromwork 序列化组件实现数据增删查改

    rest-framework序列化之Serializer models.py from django.db import models # Create your models here. class ...

随机推荐

  1. hive,分桶,内外部表,分区

    简单的word-count操作: [root@master test-map]# head -10 The_Man_of_Property.txt    #先看看数据Preface“The Forsy ...

  2. python 之列表推导式,集合推导式,以及字典推导式

    https://www.cnblogs.com/weihengblog/p/8428124.html

  3. pod install vs pod update

    Podfile文件,Podfile.lock文件 Podfile文件:指定依赖库的版本规则 Podfile.lock文件:记录当前工程中使用的依赖库的版本号 pod install会去安装podfil ...

  4. SQL 用到的操作符

    1.LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式. SELECT column_name(s) FROM table_name WHERE column_name LIKE patte ...

  5. 跨域(一)——CORS机制

    Ajax是严格遵守同源策略的,既不能从另一个域读取数据,也不能发送数据到另一个域.但是,W3C的新标准中CORS(Cross Origin Resource Sharing)推进浏览器支持这样的跨域方 ...

  6. Haskell语言学习笔记(73)Existentials

    Existentials(存在类型) Existentially quantified types(Existentially types,Existentials)是一种将一组类型归为一个类型的方式 ...

  7. Haskell语言学习笔记(71)Semigroup

    Semigroup class Semigroup a where (<>) :: a -> a -> a sconcat :: NonEmpty a -> a stim ...

  8. 19.JDBC和数据库访问.md

    1.基本功能: Java通过JDBC完成: 2.基本类型,通常用最后一种 3.JDBC简介 Java连接SQL例子: 参考:http://blog.chinaunix.net/uid-20726500 ...

  9. Hibernate 再接触 多对多单向双向关联

    情景:一个老师可能有多个学生,一个学生也可能有多个老师 多对一单向: 例如老师知道自己教哪些学生,学生却不知道自己被哪些老师教 方法:使用第三张表 分别存两张表的id annotation Stude ...

  10. windows和linux下如何远程获取操作系统版本和主机名

    远程获取windows和linux操作系统版本和主机名需要具备以下条件: 假设 主机A(windows 7),ip:192.168.12.2 主机B(centos 6.3),ip:192.168.12 ...