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)
posted @ 2019-11-22 17:24  oxtime  阅读(156)  评论(0编辑  收藏  举报