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()此值设置,会调用外面的值,可以是一个函数

 

转载于:https://www.cnblogs.com/Zhan-W/p/11294649.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值