Django在根據models生成資料庫表時報 __init__() missing 1 required positional argument: 'on_delete'
阿新 • • 發佈:2021-07-01
解決辦法:
將第十一行的程式碼改為:
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():此值設定,會呼叫外面的值,可以是一個函式。
一般情況下使用CASCADE就可以了