Django的序列化

*.Serializer与ModelSerializer都可以序列化与反序列化

序列化中的字段要与models表中的字段一致否则会报错

many=True实际上是使用了for循环


一对多序列化的思路

一对多序列化,首先创建外键表的序列化器,再创建本表的序列化器,在本表的序列化器中引用外键表的序列化


Serializer序列化 单表序列化

from  rest_framework.response import Response
from rest_framework.views import APIView
from rest_framework import serializers


#自定义序列化器
class TeacherSerializer(serializers.Serializer):
    name=serializers.CharField()
    
    
 class Teacher(APIView):
    def get(self,request):
        alist=models.Teacher.objects.all()
        #利用序列化器把数据集  变成  json格式   (注意:有instance,就是序列化,有many就是要序列化多条数据)
        res=TeacherSerializer(instance=alist,many=True)
        return Response({
            'code':1,
            'data':res.data
        })

当序列化的表中由外键是这样搞:(相当于 一对多 )

class CourseSerializer(serializers.Serializer):
    name=serializers.CharField()
    #teacher这个字段是一个外键,这里引用TeacherSerializer这个序列化器,外键实际上就是一条数据,所以用被关联表的序列化器。
    teacher=TeacherSerializer()

#把所有课程返回
class Course(APIView):
    def get(self,request):
        alist=models.Course.objects.filter()

        course_data=CourseSerializer(instance=alist,many=True)

        return Response({
            'code':1,
            'mes':course_data.data
        })

多对多序列化(注意:一定要加many=True,many=True是说我这是多条数据,需要解析一下,如果不加序列化器会认为这是一条数据)

class CourseSerializer(serializers.Serializer):
    name=serializers.CharField()
    teacher=TeacherSerializer()

#把所有课程返回   多对一
class Course(APIView):
    def get(self,request):
        alist=models.Course.objects.filter()

        course_data=CourseSerializer(instance=alist,many=True)

        return Response({
            'code':1,
            'mes':course_data.data
        })


#把所有的学生返回,对应的课程,课程的老师 都返回
class StuSerializer(serializers.Serializer):
    name=serializers.CharField(max_length=30)
    #注意: 因为是课程的多条数据需序列化所以+many=True
    Course=CourseSerializer(many=True)

class Student(APIView):
    def get(self,request):
        blist=models.Stu.objects.filter()

        res=StuSerializer(instance=blist,many=True)

        return Response({
            'code':1,
            'mes':res.data
        })

ModelSerializer序列化

class CourseSerializer(serializers.ModelSerializer):
    class Meta:
        model=models.Course
        fields="__all__"

#把所有课程返回   多对一
class Course(APIView):
    def get(self,request):
        alist=models.Course.objects.filter()

        course_data=CourseSerializer(instance=alist,many=True)

        return Response({
            'code':1,
            'mes':course_data.data
        })
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
假设我们有一个Django模型如下: ```python from django.db import models class Book(models.Model): title = models.CharField(max_length=200) author = models.CharField(max_length=200) publication_date = models.DateField() price = models.DecimalField(max_digits=6, decimal_places=2) ``` 我们可以使用Django内置的序列化工具将其序列化为JSON格式的数据。首先,我们需要在视图中导入`JsonResponse`和`serializers`: ```python from django.http import JsonResponse from django.core import serializers ``` 然后,我们可以在视图函数中查询所有的书籍,并将其序列化为JSON字符串: ```python def book_list(request): books = Book.objects.all() data = serializers.serialize('json', books) return JsonResponse(data, safe=False) ``` 在这里,`serializers.serialize`函数将查询结果序列化为JSON格式的数据,并将其存储为`data`变量。我们将其传递给`JsonResponse`构造函数,它将其转换为JSON响应并返回。 我们还可以使用Django REST框架的序列化器来实现相同的功能。我们需要首先定义一个序列化器类来指定我们要序列化的模型及其字段: ```python from rest_framework import serializers class BookSerializer(serializers.ModelSerializer): class Meta: model = Book fields = ('id', 'title', 'author', 'publication_date', 'price') ``` 接下来,我们可以在视图中使用这个序列化器来序列化我们的数据: ```python from rest_framework.decorators import api_view from rest_framework.response import Response @api_view(['GET']) def book_list(request): books = Book.objects.all() serializer = BookSerializer(books, many=True) return Response(serializer.data) ``` 在这里,我们使用`@api_view`装饰器来定义一个基于函数的视图。我们查询所有的书籍并将其传递给`BookSerializer`构造函数。`many=True`参数告诉序列化器我们要序列化多个对象。最后,我们将序列化后的数据作为响应返回。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值