1. 程式人生 > >Django在根據models生成資料庫表時報 __init__() missing 1 required positional argument: 'on_delete'

Django在根據models生成資料庫表時報 __init__() missing 1 required positional argument: 'on_delete'

#encoding=utf-8
from django.db import models
# Create your models here.
class BookInfo(models.Model):   #建立書本資訊類,繼承models.Model
    booktitle=models.CharField(max_length=20)
    bookdata=models.DateField()
class HeroInfo(models.Model):   #建立英雄資訊類
    heroname=models.CharField(max_length=10)
    herosex=models.BooleanField()
    herocontent=models.CharField(max_length=50)
    herobook=models.ForeignKey('BookInfo')   #引用外來鍵,即BookInfo物件

 

RX:

解決辦法:

將第十一行的程式碼改為:

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'
舉例說明:
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():此值設定,會呼叫外面的值,可以是一個函式。
一般情況下使用C