最近在用Django写项目时,数据映射已经写好,正当生成数据库表时系统却报错 __init__() missing 1 required positional argument: 'on_delete',这个坑不算深,报错信息很明显,下面就是报错信息:
从最后报错信息来看是owner = models.ForeignKey(User, related_name='snippets')这行代码有问题,错误提示是:TypeError: __init__() missing 1 required positional argument: 'on_delete',缺少on_delete字段
经查询,这算是Django2.0版本的新特性吧,在django2.0后,定义外键和一对一关系的时候需要加on_delete选项,此参数为了避免两个表里的数据不一致问题,不然就会报上述错误。
owner = models.ForeignKey(User, on_delete=models.CASCADE, related_name='snippets')
即添加字段on_delete并将属性设置为models.CASCADE
on_delete有CASCADE、PROTECT、SET_NULL、SET_DEFAULT、SET()五个可选择的值
CASCADE:此值设置,是级联删除。
PROTECT:此值设置,是会报完整性错误。
SET_NULL:此值设置,会把外键设置为null,前提是允许为null。
SET_DEFAULT:此值设置,会把设置为外键的默认值。
SET():此值设置,会调用外面的值,可以是一个函数。
一般情况下使用CASCADE就可以了。
经过测试运行python manage.py makemigrations无错误提示,系统正常运行,大功告成,哈哈开心
页面更新:2024-04-27
本站资料均由网友自行发布提供,仅用于学习交流。如有版权问题,请与我联系,QQ:4156828
© CopyRight 2020-2024 All Rights Reserved. Powered By 71396.com 闽ICP备11008920号-4
闽公网安备35020302034903号