django中的on_delete简单理解

django中的on_delete简单理解

你吃棒棒我吃糖!!

于 2020-02-24 11:44:45 发布

2379
收藏 7
文章标签: python django
版权

on_delete解释:当子表中的某条数据删除后,关联的外键操作

1.on_delete = models.SET_NULL
置空模式,删除时,外键字段被设置为空,前提就是blank=True, null=True,定义该字段时,允许为空。理解:删除关联数据(子表),与之关联的值设置默认值为null(父表中),这个前提需要父表中的字段可以为空。
PS:外键写在多处,且写外键只能是主键,如没设置主键,django会自动帮你创建

其他补充知识:
(1)、on_delete = None:
删除关联表的数据时,当前表与关联表的filed的行为。
(2)、on_delete = models.CASCADE:
表示级联删除,当关联表(子表)中的数据删除时,与其相对应的外键(父表)中的数据也删除。
(3)、on_delete = models.DO_NOTHING:
你删你的,父亲(外键)不想管你
(4)、on_delete = models.PROTECT:
保护模式,如采用这个方法,在删除关联数据时会抛出ProtectError错误
(5)、on_delete = models.SET_DEFAULT:
设置默认值,删除子表字段时,外键字段设置为默认值,所以定义外键的时候注意加上一个默认值。
(6)、on_delete = models.SET(值):
删除关联数据时,自定义一个值,该值只能是对应指定的实体
————————————————
版权声明:本文为CSDN博主「你吃棒棒我吃糖!!」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_45616519/article/details/104473013

你可能感兴趣的:(django中的on_delete简单理解)