151.基于Django框架的关系模型序列化、一对多关系的增删改查、一对多关系中的序列化

1.关系模型序列化

在这里插入图片描述

1.1 什么是序列化?什么是反序列化?

序列化的意思是把字典的形式转化成Json格式。当我们展示数据的时候需要使用。反序列化的话,就是Json转成字典形式,存储数据时候使用。

1.2 如何实现序列化与反序列化?

实现的方法就是,通过创建一个序列化类,继承serializers.ModelSerializer。在其中改写Meta类。具体效果看代码

1.3 代码展示

一对多模型

from django.db import models

# Create your models here.
class Classes(models.Model):
    name = models.CharField(max_length=20, verbose_name='班级名称')
class Student(models.Model):
    SEX_CHOICES = ((1,'男'),(2,'女'))
    name = models.CharField(max_length=20,verbose_name='姓名')
    age = models.IntegerField(null=True, blank=True, verbose_name='年龄')
    sex = models.IntegerField(choices=SEX_CHOICES,default=1,verbose_name='性别')
    # 多方建立外键
    classes = models.ForeignKey(Classes, on_delete=models.SET_NULL, null=True, verbose_name='班级')

序列化类

from rest_framework import serializers
from rest_app.models import *
class ClassesSerializer(serializers.ModelSerializer):
    class Meta:
        model = Classes
        fields = ['id', 'name']

class StudentSerializer(serializers.ModelSerializer):
    # 新增班级属性
    classes = ClassesSerializer() # 一定要加括号,创建实例对象。否则,只能输出id
    class Meta:
        model = Student
        fields = ['id', 'name', 'age', 'sex','classes'] #或者 ='__all__'
        

创建好就是迁移模型啦,Django迁移模型方法可以参考本专栏之前的文章
在这里插入图片描述

2. 一对多关系的增删改查

2.1 代码展示

from django.shortcuts import render
from django.views.decorators.csrf import csrf_exempt
from rest_app.models import *
from rest_app.app_serializer import StudentSerializer,ClassesSerializer
from django.http import JsonResponse,HttpResponse
from rest_framework.parsers import JSONParser
###################一对多关系表的增删改查####################
# 完成新增 查询所有,路由相同,但是请求方式不同
@csrf_exempt # 关闭csrf中间件(防止利用cookie和token攻击网站)的使用
def classes(request):
    # 判断请求方式,完成新增和查询所有
    if request.method == 'GET':
        # 查询所有数据
        stu_list = Classes.objects.all() 
        # 序列化
        serializer = ClassesSerializer(stu_list, many=True)
        # 将json格式返回客户端
        return JsonResponse(serializer.data, safe=False)
    elif request.method == 'POST':
        # 新增数据
        # 使用JSONParaser调用parse()进行反序列化为字典
        data_dict = JSONParser().parse(request)
        # 将字典传入到序列化类中
        serializer = ClassesSerializer(data=data_dict)
        # 进行验证
        if serializer.is_valid():
            # 保存数据到数据库中
            serializer.save()
            # 返回新保存的数据  状态码 201
            return JsonResponse(serializer.data, status = 201)
        return JsonResponse(serializer.errors, status=400)

# 查询一个 删除   修改
@csrf_exempt # 关闭csrf中间件(防止利用cookie和token攻击网站)的使用
def classes_detail(request,pk):
    try:
        # 根据pk获取Classes
        classes = Classes.objects.get(pk=pk)
    except Classes.DoesNotExist: #无法获取到
        return HttpResponse(status=404)
    if request.method == 'GET':
        # 根据id查询指定的Student
        # 序列化——展示数据
        serializer = ClassesSerializer(classes)
        # 返回json数据
        return JsonResponse(serializer.data)
    elif request.method == 'PUT':
        # 根据id修改Student
        # 反序列化——获取需要使用的数据时使用
        data_dict = JSONParser().parse(request)
        # 将原来的对象 字典数据传入序列化类中
        serializer = ClassesSerializer(classes, data=data_dict)
        # 进行验证
        if serializer.is_valid():
            # 更新数据到数据库
            serializer.save()
            return JsonResponse(serializer.data)
        return JsonResponse(serializer.errors, status=400)
    elif request.method == 'DELETE':
        # 根据id删除classes
        classes.delete()
        return HttpResponse(status=200)

2.2 效果展示

查询单条数据
在这里插入图片描述

查询全部数据
在这里插入图片描述
POST请求插入信息
在这里插入图片描述

PUT请求修改数据
在这里插入图片描述
DELETE删除数据
在这里插入图片描述

3.一对多关系中在一方想获取多方数据并序列化方法

首先,在模型中的多方应该在外键中加入属性related_name,在模型的一方中,使用属性名记录多方的序列化后字段。在fields中添加入属性名。
模型

from django.db import models

# Create your models here.
class Classes(models.Model):
    name = models.CharField(max_length=20, verbose_name='班级名称')
class Student(models.Model):
    SEX_CHOICES = ((1,'男'),(2,'女'))
    name = models.CharField(max_length=20,verbose_name='姓名')
    age = models.IntegerField(null=True, blank=True, verbose_name='年龄')
    sex = models.IntegerField(choices=SEX_CHOICES,default=1,verbose_name='性别')
    # 多方建立外键
    classes = models.ForeignKey(Classes, related_name='students' ,on_delete=models.SET_NULL, null=True, verbose_name='班级')

序列化

from rest_framework import serializers
from rest_app.models import *
# 根据学生获取学生所在班级
# class ClassesSerializer(serializers.ModelSerializer):
#     class Meta:
#         model = Classes
#         fields = ['id', 'name']

# class StudentSerializer(serializers.ModelSerializer):
#     # 新增班级属性
#     classes = ClassesSerializer() # 一定要加括号,创建实例对象。否则,只能输出id
#     class Meta:
#         model = Student
#         fields = ['id', 'name', 'age', 'sex','classes'] #或者 ='__all__'

# 根据班级获取班级所有学生信息
class StudentSerializer(serializers.ModelSerializer):
    class Meta:
        model = Student
        fields = ['id', 'name', 'age', 'sex'] #或者 ='__all__'

class ClassesSerializer(serializers.ModelSerializer):
    # students 属性要和student类中外键classes属性 related_name='students'
    # 多条记录 指定many = True, read_only=True
    students = StudentSerializer(many=True, read_only=True) 
    class Meta:
        model = Classes
        fields = ['id', 'name','students']        

效果展示
在这里插入图片描述

4. 手动处理关系字段

在上述中,由于类的引用关系的原因,左右只能自动序列化一个关系字段,如果业务需求,需要2个关系字段都序列化,那么就需要使用到serializers.RelatedField类,手动处理字段关系。、
序列化

from rest_framework import serializers
from rest_app.models import *
# 根据学生获取学生所在班级
# class ClassesSerializer(serializers.ModelSerializer):
#     class Meta:
#         model = Classes
#         fields = ['id', 'name']

# class StudentSerializer(serializers.ModelSerializer):
#     # 新增班级属性
#     classes = ClassesSerializer() # 一定要加括号,创建实例对象。否则,只能输出id
#     class Meta:
#         model = Student
#         fields = ['id', 'name', 'age', 'sex','classes'] #或者 ='__all__'

class ClassesRelatedField(serializers.RelatedField):
    def to_representation(self, value):
        return {'id':value.id, 'name':value.name}
# 根据班级获取班级所有学生信息
class StudentSerializer(serializers.ModelSerializer):
    # classes 属性名和Student类中外键属性名相同
    classes = ClassesRelatedField(read_only=True)
    class Meta:
        model = Student
        fields = ['id', 'name', 'age', 'sex','classes'] #或者 ='__all__'
class ClassesSerializer(serializers.ModelSerializer):
    # students 属性要和student类中外键classes属性 related_name='students'
    # 多条记录 指定many = True, read_only=True
    students = StudentSerializer(many=True, read_only=True) 
    class Meta:
        model = Classes
        fields = ['id', 'name','students']


        

在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,我可以提供一个简单的示例代码,以便您了解如何使用Django进行前后端分离的增删改查操作。请注意,以下代码仅供参考,您需要根据自己的需求进行修改和完善。 首先,我们需要创建一个Django项目,并在其创建一个应用程序。在应用程序,我们需要定义模型以及处理HTTP请求的视图函数。 下面是一个简单的模型示例: ```python # models.py from django.db import models class Product(models.Model): name = models.CharField(max_length=100) description = models.TextField() price = models.DecimalField(max_digits=10, decimal_places=2) ``` 然后,我们需要创建视图函数来处理HTTP请求。在这个示例,我们将创建一个基于类的视图,并使用Django Rest Framework提供的GenericAPIView和ModelMixin来实现CRUD操作。 ```python # views.py from rest_framework import generics, mixins from .models import Product from .serializers import ProductSerializer class ProductListCreateAPIView(mixins.ListModelMixin, mixins.CreateModelMixin, generics.GenericAPIView): queryset = Product.objects.all() serializer_class = ProductSerializer def get(self, request, *args, **kwargs): return self.list(request, *args, **kwargs) def post(self, request, *args, **kwargs): return self.create(request, *args, **kwargs) class ProductRetrieveUpdateDestroyAPIView(mixins.RetrieveModelMixin, mixins.UpdateModelMixin, mixins.DestroyModelMixin, generics.GenericAPIView): queryset = Product.objects.all() serializer_class = ProductSerializer def get(self, request, *args, **kwargs): return self.retrieve(request, *args, **kwargs) def put(self, request, *args, **kwargs): return self.update(request, *args, **kwargs) def delete(self, request, *args, **kwargs): return self.destroy(request, *args, **kwargs) ``` 上述视图函数,我们定义了两个基于类的视图:ProductListCreateAPIView和ProductRetrieveUpdateDestroyAPIView。ProductListCreateAPIView用于创建和列出产品,ProductRetrieveUpdateDestroyAPIView用于获取、更新和删除一个特定的产品。 接下来,我们需要定义序列化来将模型转换为JSON格式。在这个示例,我们使用Django Rest Framework提供的ModelSerializer。 ```python # serializers.py from rest_framework import serializers from .models import Product class ProductSerializer(serializers.ModelSerializer): class Meta: model = Product fields = '__all__' ``` 最后,我们需要在urls.py定义路由,以便将HTTP请求路由到正确的视图函数。 ```python # urls.py from django.urls import path from .views import ProductListCreateAPIView, ProductRetrieveUpdateDestroyAPIView urlpatterns = [ path('products/', ProductListCreateAPIView.as_view(), name='product_list_create'), path('products/<int:pk>/', ProductRetrieveUpdateDestroyAPIView.as_view(), name='product_retrieve_update_destroy'), ] ``` 现在,我们已经完成了一个简单的Django后端分离的增删改查示例。您可以使用前端框架(如React或Vue.js)来处理HTTP请求并呈现数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

想成为数据分析师的开发工程师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值