Django2.0外键参数on_delete的使用方法

最新的django2.0使用外键(ForeignKey)和一对一(OneToOneField)的时候,必须添加on_delete参数,不然就会报错。

刚使用django2.0的朋友,总是遇到类似下面的报错,这就是没有给外键添加on_delete参数的原因。

TypeError: __init__() missing 1 required positional argument: 'on_delete'


官方案例:

一对一(OneToOneField)

from django.conf import settings
from django.db import models
class MySpecialUser(models.Model):
    user = models.OneToOneField(settings.AUTH_USER_MODEL,on_delete=models.CASCADE,)
    supervisor = models.OneToOneField(settings.AUTH_USER_MODEL,on_delete=models.CASCADE,related_name='supervisor_of',)

一对多(ForeignKey)

from django.db import models
class AbstractCar(models.Model):
    manufacturer = models.ForeignKey('Manufacturer', on_delete=models.CASCADE)
    class Meta:
        abstract = True

下面下整理的on_delete参数的各个值的含义:

on_delete=None,               # 删除关联表中的数据时,当前表与其关联的field的行为
on_delete=models.CASCADE,     # 删除关联数据,与之关联也删除
on_delete=models.DO_NOTHING,  # 删除关联数据,什么也不做
on_delete=models.PROTECT,     # 删除关联数据,引发错误ProtectedError
# models.ForeignKey('关联表', on_delete=models.SET_NULL, blank=True, null=True)
on_delete=models.SET_NULL,    # 删除关联数据,与之关联的值设置为null(前提FK字段需要设置为可空,一对一同理)
# models.ForeignKey('关联表', on_delete=models.SET_DEFAULT, default='默认值')
on_delete=models.SET_DEFAULT, # 删除关联数据,与之关联的值设置为默认值(前提FK字段需要设置默认值,一对一同理)
on_delete=models.SET,         # 删除关联数据,
 a. 与之关联的值设置为指定值,设置:models.SET(值)
 b. 与之关联的值设置为可执行对象的返回值,设置:models.SET(可执行对象)


多对多不需要on_delete,这就不多说了。想要了解更多on_delete的资料,请点击下面去官网查看。

django.db.models.ForeignKey

码字不容易,转载请加上本文链接和注明出处。如果上面的内容帮到你了,可以打赏作者喝杯茶。

117.jpg

文章评论 4

  • 原来这用法是这样,明白了。 可惜缺少一个收藏功能

  • 只要评论文章,就能在个人中心里查看到评论过的文章。和收藏功能类似,所以没有做收藏功能。

  • 假如没评论或者不知道评论说什么,或者只是点开有别的事儿忙,关闭了不就看不到了。要是只有评论才显示记录,不但增加了垃圾评论量,还有对于优质文章找起来比较麻烦。