在一对多关系中,例如主机对应多个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错