时间:2021-07-01 10:21:17 帮助过:5人阅读
程序代码如下:
# 创建应用程序数据表模型(对应数据库的相关操作)
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'
标签:har efault class sts port image 技术 操作 key