zoukankan      html  css  js  c++  java
  • 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 1.6 最佳实践: 如何设置django项目的设置(settings.py)和部署文件(requirements.txt)
    算法七:广度优先搜索
    sqldependency 支持的select
    ghostDoct 使用 (转 http://www.cnblogs.com/RockyMyx/archive/2010/04/20/Project-Route-Using-GhostDoc.html)
    Jenkins 使用学习笔记
    C# 反射类型转换
    时间分割线:2016年1月的文章都是从以前chinaunix的博客文章
    Error 42 error C2784: 'bool std::operator <(const std::_Tree<_Traits>
    JNI的类路径问题
    【转】不用临时变量也可以交换变量的值
  • 原文地址:https://www.cnblogs.com/Zhan-W/p/11294649.html
Copyright © 2011-2022 走看看