Django在使用models生成数据库表时报错: __init__() missing 1 required positional argument: 'on_delete'

Django 提供完善的模型(model)层主要用来建立和存取数据,不须要咱们直接对数据库操做。
Django 模型基础知识:
  一、每一个模型是一个 Python 类,继承 django.db.models.model 类。
  二、该模型的每一个属性表示一个数据库表字段。数据库

程序代码以下:django

# 建立应用程序数据表模型(对应数据库的相关操做)
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,这个不耍赖,确实是少了一个这样的参数。函数

其实在编辑器中这一步的代码也是有提示的:spa

在这一行的末尾括号处有个小的下划线。前边说了少了一个参数 ,可是应该怎么把这个参数加进去呢????code

解决办法:对象

将文中的这一行代码:blog

      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() 此值设置,会调用外面的值,能够是一个函数
相关文章
相关标签/搜索