学习外键删除要涉及几种外键的保护类型,包含外键的级别:级联删除,保护等等
如果一个模型使用了外键。那么在对方那个模型被删掉后,该进行什么样的操作。可以通过on_delete来指定。可以指定的类型如下:
1.CASCADE:级联操作。如果外键对应的那条数据被删除了,那么这条数据也会被删除。
2.PROTECT:受保护。即只要这条数据引用了外键的那条数据,那么就不能删除外键的那条数据。
3.SET_NULL:设置为空。如果外键的那条数据被删除了,那么在本条数据上就将这个字段设置为空。如果设置这个选项,前提是要指定这个字段可以为空。
4.SET_DEFAULT:设置默认值。如果外键的那条数据被删除了,那么本条数据上就将这个字段设置为默认值。如果设置这个选项,前提是要指定这个字段一个默认值。
5.SET():如果外键的那条数据被删除了。那么将会获取SET函数中的值来作为这个外键的值。SET函数可以接收一个可以调用的对象(比如函数或者方法),如果是可以调用的对象,那么会将这个对象调用后的结果作为值返回回去。
6.DO_NOTHING:不采取任何行为。一切全看数据库级别的约束。
class Article(models.Model):
title = models.CharField(max_length=20, null=True)
content = models.TextField(null=True)
# 级联删除
# 级联删除
# category = models.ForeignKey('Category', on_delete=models.CASCADE, null=True)
# PROTECT
# category = models.ForeignKey('Category', on_delete=models.PROTECT)
# SET_NULL 前提是可以为null
category = models.ForeignKey('Category', on_delete=models.SET_NULL, null=True)
# SET_DEFAULT 前提是需要把它改为别的外键的id
# category = models.ForeignKey('Category', on_delete=models.SET_DEFAULT, default=4)
# category = models.ForeignKey('Category', on_delete=models.SET_DEFAULT, default=Category.objects.get(pk=2))
# category = models.ForeignKey('Category', on_delete=models.SET(Category.objects.get(pk=2)))