Django ORM 级联删除

Posted 摆渡人1993

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Django ORM 级联删除相关的知识,希望对你有一定的参考价值。

在一对多关系中,例如主机对应多个role,每个role对应1个主机,

当删除了某个主机时候,发现对应的role也被删除了,于是查了手册,应该如下写:

class Host(models.Model):  
    hostname = models.CharField(max_length=20,primary_key=True, blank=False)  
    static_ip = models.CharField(max_length=20,unique = True)  
  
class CCRole(models.Model):  
    name = models.CharField(max_length = 20,primary_key = True)  
    host = models.ForeignKey(Host,null=True,blank=True,on_delete=models.SET_NULL)  

给ForeignKey增加属性,

 

on_delete=models.SET_NULL

即可。

该属性还有其他值可选:

CASCADE: 默认的,级联删除

PROTECT: 通过抛出django.db.models.ProtectedErrordjango.db.models.ProtectedError错误来阻止删除关联的对象 

SET_NULL: 设置ForeignKey 为 null; 这个只有设置了null 为 True的情况才能用

SET_DEFAULT: 设置 ForeignKey 为默认值; 默认值必须预先设置

SET(): 设置为某个方法返回的值

DO_NOTHING: 什么都不做,如果数据库设置必须关联则会报IntegrityError错

  

以上是关于Django ORM 级联删除的主要内容,如果未能解决你的问题,请参考以下文章

Django聚合查询 orm字段及属性

Doctrine 2 ORM 级联删除相关实体

1128 聚合查询 orm字段及属性

为啥 Django 对外键进行级联删除?

Django,级联移动到单独的表而不是级联删除

Django级联删除反向外键