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

报错的原因呢,就是在设计model时我弄了个外键,然后就报错了。。。

  
不难看出,它是想让我们在表与表关联时添加一个on_delete参数
解决办法:
如其所愿,加上on_delete=models.CASCADE

 
趁机整理一下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,         # 删除关联数据, 与之关联的值设置为指定值/ 与之关联的值设置为可执行对象的返回值

一般的话,设on_delete = models.CASCADE就够用的了

posted @ 2018-09-18 15:43  WoLykos  阅读(415)  评论(0编辑  收藏  举报