Django在使用models生成数据库表时报错: __init__() missing 1 required positional argument: 'on_delete'
Posted zhan-w
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Django在使用models生成数据库表时报错: __init__() missing 1 required positional argument: 'on_delete'相关的知识,希望对你有一定的参考价值。
Django 提供完善的模型(model)层主要用来创建和存取数据,不需要我们直接对数据库操作。
Django 模型基础知识:
1、每个模型是一个 Python 类,继承 django.db.models.model 类。
2、该模型的每个属性表示一个数据库表字段。
程序代码如下:
# 创建应用程序数据表模型(对应数据库的相关操作)
from django.db import models # 导入models模块
class Event(models.Model): # 创建Event类,继承models.Model
name = models.CharField(max_length=100)
limit = models.IntegerField()
status = models.BooleanField()
def __str__(self):
return self.name
class Guests(models.Model): # 创建Guests,继承models.Model
event = models.ForeignKey(‘Event‘) # 引用外键,即Event对象
realname = models.CharField(max_length=64)
phone = models.CharField(max_length=16)
class Meta:
unique_together = ("event","phone")
def __str__(self):
return self.realname
执行后报错信息如下:
根据报错提示可以看出原因 ,说少了一个必须的位置参数:on_delete,这个不耍赖,确实是少了一个这样的参数。
其实在编辑器中这一步的代码也是有提示的:
在这一行的末尾括号处有个小的下划线。前边说了少了一个参数 ,但是应该怎么把这个参数加进去呢????
解决办法:
将文中的这一行代码:
event = models.ForeignKey(‘Event‘)
改为:
event = models.ForeignKey(‘Event‘,on_delete = models.CASCADE)
虽然知道为解决办法但是到底为啥子会报这个错呢?
原因:在django2.0后,定义外键和一对一关系的时候需要加on_delete选项,此参数为了避免两个表里的数据不一致问题,不然会报错。
当然on_delete这个参数的值不仅仅有:CASCADE
还有如下:
CASCADE | 此值设置,是级联删除 |
PROTECT | 此值设置,是会报完整性错误 |
SET_NULL | 此值设置,会把外键设置为null,前提是允许为null |
SET_DEFAULT | 此值设置,会把设置为外键的默认值 |
SET() | 此值设置,会调用外面的值,可以是一个函数 |
以上是关于Django在使用models生成数据库表时报错: __init__() missing 1 required positional argument: 'on_delete'的主要内容,如果未能解决你的问题,请参考以下文章
Django在根据models生成数据库表时报 __init__() missing 1 required positional argument: 'on_delete'
Django2.1在根据models生成数据库表时报 __init__() missing 1 required positional argument: 'on_delete'
python3 django2.0 在生成数据库表时报错: TypeError: __init__() missing 1 required positional argument: 'o(代
Django在根据models生成数据库表时报 __init__() missing 1 required positional argument: 'on_delete'