亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在 GORM SQLite 中強制執行外鍵約束

在 GORM SQLite 中強制執行外鍵約束

Go
慕尼黑5688855 2022-10-17 16:05:22
答:db.Exec("PRAGMA foreign_keys = ON")用于強制執行外鍵約束檢查。謝謝@outdead當我使用 GORM 更新我的 SQLite 數據庫時,不會強制執行外鍵約束。我有這兩個模型:type Cat struct {    ID      int       Name    string    Breed   string    OwnerID int      Owner   Owner }type Owner struct {    ID    int       Name  string    Phone string}它正確地創建了一個外鍵約束,其中owner_id引用id. owners這可以通過.schema cats在 SQLite shell 中運行:CREATE TABLE `cats` (`id` integer,`name` text,`breed` text,`owner_id` integer,PRIMARY KEY (`id`),CONSTRAINT `fk_cats_owner` FOREIGN KEY (`owner_id`) REFERENCES `owners`(`id`));我試過PRAGMA foreign_keys = ON;在 SQLite shell 中運行命令時強制執行外鍵。如果我嘗試將 an 更新為中不存在的owner_idan ,我會得到:,這是我想要的行為,但是,GORM 仍然能夠執行這些更新而不會收到此錯誤。idownersError: FOREIGN KEY constraint failed
查看完整描述

1 回答

?
POPMUISE

TA貢獻1765條經驗 獲得超5個贊

您需要執行查詢才能PRAGMA foreign_keys在更新之前打開


if res := db.Exec("PRAGMA foreign_keys = ON", nil); res.Error != nil {

    return res.Error

}


查看完整回答
反對 回復 2022-10-17
  • 1 回答
  • 0 關注
  • 206 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號