django 外键删除

如果一个模型使用了外键。那么在对方那个模型被删除掉后,该进行什么样的操作。可以通过 on_delete 来指定。可以指定的类型如下:

1、CASCADE:级联操作。如果外键对应的那条数据被删除了,那么这条数据也会被删除。

def index(res):
    user = User.objects.get(pk=2)
    user.delete()
    return '删除成功'

现在我们删除User表中的id为2的数据,结果外键关联的数据也被删除了:

2、PROTECT:受保护的。即只要这条数据引用了外键的那条数据,那么就不能删除外键的那条数据。如果强制删除,会报错:

3、SET_NULL:设置为空。如果外键的那条数据被删除了,那么在本条数据上讲就将这个字段设置为空,如果设置这个选项,前提是要指定这个字段可以为空( null = True )

class Article(models.Model):
    author = models.ForeignKey('User', on_delete=models.SET_NULL, null=True)

4、SET_DEFAULT:设置默认值。如果外键的那条数据被删除了,那么本条数据上就将这个字段设置为默认值。如果设置这个选项,前提是要指定这个字段一个默认值。

如下:

如果我们删除外键关联的那条数据,那么author默认会把外键关联到User表中的id为2的数据中。

class User(models.Model):
    username = models.CharField(max_length=50)
    password = models.CharField(max_length=50)
    class Meta:
        db_table = 'User'
class Article(models.Model):
    title = models.CharField(max_length=100)
    content = models.TextField()
    author = models.ForeignKey('User', on_delete=models.SET_DEFAULT, null=True, default=User.objects.get(pk=2))
    class Meta:
        db_table = 'Article'

5、SET( ):如果外键的那条数据被删除了。那么将会获取SET函数中的值来作为这个外键的值。SET函数可以接收一个可以调用的对象(比如函数或者方法),如果是可以调用的对象,那么会将这个对象调用后的结果作为值返回回去。

效果与SET_DEFAULT一样:

class User(models.Model):
    pass
class Article(models.Model):
    author = models.ForeignKey('User', on_delete=models.SET(User.objects.get(pk=2)), null=True)

6、DO_NOTHIMG:不采取任何行为。一切全看数据库级别的约束。

以上这些选项只是Django级别的,数据级别依旧是RESTRICT(相当于 ORM 中的PROTECT) :

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值