TypeError: __init__() missing 1 required positional argument: 'on_delete'
Python 3.8 以上创建数据库 需在加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
就够用的了
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!