如果一个模型使用了外键。那么在对方那个模型被删除掉后,该进行什么样的操作。可以通过 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) :