Django在根据models生成数据库表时报 __init__() missing 1 required positional argument: 'on_delete'
code:
1 #encoding=utf-82 from django.db import models3 # Create your models here.4 class BookInfo(models.Model): #創(chuàng)建書本信息類,繼承models.Model5 booktitle=models.CharField(max_length=20)6 bookdata=models.DateField()7 class HeroInfo(models.Model): #創(chuàng)建英雄信息類8 heroname=models.CharField(max_length=10)9 herosex=models.BooleanField() 10 herocontent=models.CharField(max_length=50) 11 herobook=models.ForeignKey('BookInfo') #引用外鍵,即BookInfo對(duì)象RX:
解決辦法:
將第十一行的代碼改為:
herobook=models.ForeignKey('BookInfo',on_delete=models.CASCADE,) 即在外鍵值的后面加上 on_delete=models.CASCADE原因:
在django2.0后,定義外鍵和一對(duì)一關(guān)系的時(shí)候需要加on_delete選項(xiàng),此參數(shù)為了避免兩個(gè)表里的數(shù)據(jù)不一致問題,不然會(huì)報(bào)錯(cuò):
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) --在老版本這個(gè)參數(shù)(models.CASCADE)是默認(rèn)值
owner=models.ForeignKey(UserProfile,on_delete=models.CASCADE) --在老版本這個(gè)參數(shù)(models.CASCADE)是默認(rèn)值
參數(shù)說明:
on_delete有CASCADE、PROTECT、SET_NULL、SET_DEFAULT、SET()五個(gè)可選擇的值
CASCADE:此值設(shè)置,是級(jí)聯(lián)刪除。
PROTECT:此值設(shè)置,是會(huì)報(bào)完整性錯(cuò)誤。
SET_NULL:此值設(shè)置,會(huì)把外鍵設(shè)置為null,前提是允許為null。
SET_DEFAULT:此值設(shè)置,會(huì)把設(shè)置為外鍵的默認(rèn)值。
SET():此值設(shè)置,會(huì)調(diào)用外面的值,可以是一個(gè)函數(shù)。
一般情況下使用CASCADE就可以了。
轉(zhuǎn)載自https://www.cnblogs.com/phyger/p/8035253.html
?
總結(jié)
以上是生活随笔為你收集整理的Django在根据models生成数据库表时报 __init__() missing 1 required positional argument: 'on_delete'的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: grpc例子
- 下一篇: php mysql 平均分_平均评级计算