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


    from django.db import models
    
    
    # Create your models here.
    class Event(models.Model):
        name = models.CharField(max_length=100)
        limit = models.IntegerField()
        status = models.BooleanField()
        address = models.CharField(max_length=20)
        start_time = models.DateTimeField('event time')
        create_time = models.DateTimeField(auto_now=True)
    
        def __init__(self):
            return self.name
    
    
    class Guest(models.Model):
        event = models.ForeignKey(Event)
        realname = models.CharField(max_length=64)
        phone = models.CharField(max_length=16)
        email = models.EmailField()
        sign = models.BooleanField()
        create_time = models.DateTimeField(auto_now=True)
    
        class Meta:
            unique_together = ('event', 'phone')
    
        def __str__(self):
            return self.realname
    

      

    解决方法:

    将第18行的代码改为:

    event = models.ForeignKey(Event,on_delete=models.CASCADE)
    原因:
    
    在django2.0后,定义外键和一对一关系的时候需要加on_delete选项,此参数为了避免两个表里的数据不一致问题,不然会报错:
    TypeError: __init__() missing 1 required positional argument: 'on_delete'
    举例说明:
    user=models.OneToOneField(User)
    owner=models.ForeignKey(UserProfile)
    需要改成:
    user=models.OneToOneField(User,on_delete=models.CASCADE) --在老版本这个参数(models.CASCADE)是默认值
    owner=models.ForeignKey(UserProfile,on_delete=models.CASCADE) --在老版本这个参数(models.CASCADE)是默认值
    参数说明:
    on_delete有CASCADE、PROTECT、SET_NULL、SET_DEFAULT、SET()五个可选择的值
    CASCADE:此值设置,是级联删除。
    PROTECT:此值设置,是会报完整性错误。
    SET_NULL:此值设置,会把外键设置为null,前提是允许为null。
    SET_DEFAULT:此值设置,会把设置为外键的默认值。
    SET():此值设置,会调用外面的值,可以是一个函数。
    一般情况下使用CASCADE就可以了。
  • 相关阅读:
    输入输出重定向
    Tkinter程序屏幕居中
    从Web Controls到DHTML学习随想
    一个没暂时没有办法实现的问题和一个有意思的小问题!
    [学习笔记]几个英语短句(1)
    [读书笔记]My LifeBill Clinton
    [学习笔记]几个英语短句(2)
    结合MS Web Controls做文件上传的解决方案!
    IIS的一个莫名错误--Server Application Unavailable
    Google Sitemaps(测试版)帮助:使用 Sitemap 协议
  • 原文地址:https://www.cnblogs.com/feifei-cyj/p/11003768.html
Copyright © 2020-2023  润新知