zoukankan      html  css  js  c++  java
  • orm多表关系

    1、(重点)二次封装Response:自定义APIResponse继承Response,重写__init__方法
    {'status':0,'msg'ok','results':{}}
    class APIResponse(Response):
    	def __init__(self, status, msg, ..., **kwargs):
    		# status+msg+kwargs => data
    		super().__init__(data, ...)
    
    2、(正常)设置了abstract为True的模型类,称之为基表,这样的模型类是专门作为基类来提供公有属性的
    A(name)、B(title)-Meta-abstract=True、C(B)、D(B)
    
    3、(重点)ORM多表关联操作:
    	外键所放位置
            一对多:外键放在多的一方
    		多对多:外键放在常用的一方
    		一对一:外键放在不常用的一方
    		外键字段为正向查询字段,related_name是反向查询字段
    	外键如何断关联
    		设置外键字段db_constraint=False
    	外键间的级联关系
    		一对一:作者没了,详情也没:on_delete=models.CASCADE
    		一对多:出版社没了,书还是那个出版社出版:on_delete=models.DO_NOTHING
    		一对多:部门没了,员工没有部门(空不能):null=True, on_delete=models.SET_NULL
    		一对多:部门没了,员工进入默认部门(默认值):default=0, on_delete=models.SET_DEFAULT
    		多对多:不能设置on_delete
    4、(重点)连表序列化,在Model类中定义插拔序列化方法属性,完成连表查询
    5、(正常)子序列化可以辅助快速实现自定义外键深度的序列化,但是不能进行反序化
    6、(重点)单查群查接口,序列化类提供序列化对象,many参数控制着操作的数据是一条还是多条
    ModelSerializer(obj) | ModelSerializer(obj, many=True)
    
    7、(正常)单删群删接口,后台操作删除字段即可,前台提供pk就是单删,提供pks就是群删
    pk,pks => pks => filter(pk__in=pks,is_delete=False).update(is_delete=True)
    
    try:
    	# 可能有异常的代码(数据库操作)
    except:
    	raise Exception('某某数据库操作异常了')
    	
    8、(重点)单增群增接口,根据数据判断是单增还是群增,对应序列化类要设置many,而序列化类只需要通过data即可
    ModelSerializer(data=request_data) | ModelSerializer(data=request_data, many=True)
    
    9、(正常)单局部改,序列化类参数instance=修改的对象, data=修改的数据, partial=是否能局部修改,单整体修改就是partial=False(默认就是False)
    ModelSerializer(instance=obj,data=data,partial=True)
    
    10、(了解)群改,前台提供的数据,后台要转化成要修改的对象们和用来更新的数据们,ModelSerializer设置list_serializer_class关联自己的ListSerializer,重写update方法,完成群改
    ModelSerializer(instance=objs,data=datas,many=True,partial=True)
    
  • 相关阅读:
    将数组转换为对象
    react常见组件问题Can't perform a React state update on an unmounted component
    React定位到滚动条底部
    React使用定时器interval
    CSS 如何做到隐藏滚动条的同时可以滚动
    css实现字母或数字强制换行
    如何让div的滚动条在上下左右都出现
    js学习
    JavaScript介绍
    前端跨域
  • 原文地址:https://www.cnblogs.com/oxtime/p/11912855.html
Copyright © 2011-2022 走看看