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

代码:
from django.db import models
# Create your models here.
class BookInfo(models.Model):
    title=models.CharField(max_length=20)
    pub_date=models.DateField()
class HeroInfo(models.Model):
    name=models.CharField(max_length=10)
    content=models.CharField(max_length=100)
    gender=models.BooleanField(default=True)
    book=models.ForeignKey(BookInfo)      #引用外键,即BookInfo对象
报错:
 

解决:

引用外键时应为:herobook=models.ForeignKey('BookInfo',on_delete=models.CASCADE,)

即在外键值的后面加上 on_delete=models.CASCADE

原因:

在django2.0后,定义外键和一对一关系的时候需要加on_delete选项,此参数为了避免两个表里的数据不一致问题,不然会报错:TypeError: __init__() missing 1 required positional argument: 'on_delete'

参数说明:
            on_delete有CASCADE、PROTECT、SET_NULL、SET_DEFAULT、SET()五个可选择的值,一般情况下使用CASCADE就可以了。
            CASCADE:此值设置,是级联删除。
            PROTECT:此值设置,是会报完整性错误。
            SET_NULL:此值设置,会把外键设置为null,前提是允许为null。
            SET_DEFAULT:此值设置,会把设置为外键的默认值。
            SET():此值设置,会调用外面的值,可以是一个函数。
           

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值