django2.X 模型类兼容 外键关联on_delete


模型类引入外键的时候需要添加

on_delete=models.CASCADE

  

例:
以往版本:

name = models.ForeignKey('Name')
type = models.ForeignKey('Type',verbose_name='类别')

  

需改为:

name = models.ForeignKey('Name',on_delete=models.CASCADE)
type = models.ForeignKey('Type',on_delete=models.CASCADE,verbose_name='类别')

  

 

不然报错:
TypeError: __init__() missing 1 required positional argument: 'on_delete'

 


on_delete作用:  如果外键所关联的对应数据表被删除的话, 此模型类数据的应对方式.

在django2.X之前版本, on_delete(default='CASCADE'), CASCADE是缺省值, 更新之后需要进行手动设置.




一般依然选CASCADE.

on_delete有六种选项, 除了CASCADE外, 还有PROTECT、SET()、SET_NULL、SET_DEFAULT、DO_NOTHING


on_delete属性详解:

CASCADE(级联删除):当关联表中的数据删除时,该外键字段也随之删除

PROTECT(保护模式): 如果采用该选项,删除的时候,会抛出ProtectedError错误

SET(): 自定义一个值,对应实体

SET_NULL(置空):当关联表中的数据删除时,该外键置空,当然,此外键字段得允许为空,null=True

SET_DEFAULT(设置默认值):删除的时候,外键字段设置为默认值,所以定义外键的时候注意加上一个默认值

DO_NOTHING: 啥也不干

posted @ 2019-09-28 21:37  Jrri  阅读(275)  评论(0编辑  收藏  举报