Django2.0在python manage.py makermigrations创建models时的坑

Django生成数据库表,python manage.py makemigrations

最近在用Django写项目时,数据映射已经写好,正当生成数据库表时系统却报错 __init__() missing 1 required positional argument: 'on_delete',这个坑不算深,报错信息很明显,下面就是报错信息:

Django2.0在python manage.py makermigrations创建models时的坑

错误详情

从最后报错信息来看是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

标签:会报   表里   大功告成   字段   函数   完整性   正当   选项   属性   前提   错误   数据库   数据   系统   科技   信息

1 2 3 4 5

上滑加载更多 ↓
推荐阅读:
友情链接:
更多:

本站资料均由网友自行发布提供,仅用于学习交流。如有版权问题,请与我联系,QQ:4156828  

© CopyRight 2020-2024 All Rights Reserved. Powered By 71396.com 闽ICP备11008920号-4
闽公网安备35020302034903号

Top