目錄
問題內容
解決方法
首頁 後端開發 Golang GORM 中的外鍵未更新

GORM 中的外鍵未更新

Feb 09, 2024 am 11:57 AM

GORM 中的外键未更新

最近在使用GORM時,我發現一個問題-外鍵未更新的情況。當我在關聯的表中更新了外鍵欄位的值時,卻沒有同步更新到另一張表中。透過調查和研究,我發現這是因為GORM預設不會自動更新外鍵欄位。這個問題困擾了我一段時間,所以我決定將解決方法分享給大家。在本文中,我將向大家介紹如何使用GORM來正確更新外鍵字段,以避免這個問題。

問題內容

我有兩張桌子,一張是公司

1

2

3

4

5

6

type Company struct {

    Id        uuid.UUID `gorm:"column:id;primaryKey;"`

    CreatedAt time.Time `gorm:"index;column:createdAt"`

    UpdatedAt time.Time `gorm:"index;column:updatedAt"`

    Name      string    `gorm:"column:name" binding:"required"`

}

登入後複製

另一個是product_entitlement

1

2

3

4

5

6

7

8

type ProductEntitlement struct {

ID        uuid.UUID

CreatedAt time.Time `gorm:"index;column:createdAt"`

UpdatedAt time.Time `gorm:"index;column:updatedAt"`

Type       string    `gorm:"column:type" binding:"required"`

CompanyID  uuid.UUID `gorm:"column:companyId;size:36"`

Company    Company   `gorm:"foreignKey:CompanyID"`

}

登入後複製

CompanyID 是外鍵。 CompanyID 包含來自 Company.Id 的值

更新插入完成後,每次都會插入新行。這是我們正在使用的程式碼

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

func UpdateEntitlement(c *gin.Context) {

cid := c.Param("companyId")

    id := c.Param("entitlementId")

    eid := uuid.MustParse(id)

    log.Println(eid)

    uid := uuid.MustParse(cid)

    log.Println(uid)

    var entitlementRequest entities.ProductEntitlement

    if err := c.BindJSON(&entitlementRequest); err != nil {

        log.Println(err)

        fmt.Println("ERROR: ", err)

        c.JSON(400, gin.H{"error": "Invalid JSON format"})

        return

    }

    if err := database.DB.Clauses(clause.OnConflict{

        Columns:   []clause.Column{{Name: "id"}},

        UpdateAll: true,

    }).Create(&entitlementRequest).Error; err != nil {

        log.Println(err)

    }

}

登入後複製

但它總是失敗並給出錯誤

BD820BD3F94A2A45E18ED8E8094EF395

如果 ID 存在,我想更新 Product_entitlement,否則建立一個新的

網址如下, http://localhost:8080/company/{{companyId}}/product/{{companyId}} 並使用 PUT 方法 身體是

{「類型」:「自動」}

解決方法

如果它對某人有幫助,我們可以使用FirstOrCreate 函數來檢查id 是否存在並進行更新,如果不存在則建立一個新的。

要指派外鍵,我們需要將值指派給相關表,

entitlementRequest.CompanyID = uid

#

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

func UpdateEntitlement(c *gin.Context) {

    cid := c.Param("companyId")

    uid := uuid.MustParse(cid)

    eid := c.Param("entitlementId")

    nid := uuid.MustParse(eid)

    var entitlementRequest entities.ProductEntitlement

    entitlementRequest.CompanyID = uid

 

    if err := c.BindJSON(&entitlementRequest); err != nil {

        fmt.Println("ERROR: ", err)

        c.JSON(400, gin.H{"error": "Invalid JSON format"})

        return

    }

    if err := database.DB.Where("id = ?", nid).

        Assign(entitlementRequest).

        FirstOrCreate(&entitlementRequest).Error; err != nil {

        c.JSON(http.StatusBadRequest, gin.H{"error": "Record not found!"})

        return

    }

    c.JSON(http.StatusOK, gin.H{"error": "Product entitlement upserted successfully"})

}

登入後複製

以上是GORM 中的外鍵未更新的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Go語言包導入:帶下劃線和不帶下劃線的區別是什麼? Go語言包導入:帶下劃線和不帶下劃線的區別是什麼? Mar 03, 2025 pm 05:17 PM

Go語言包導入:帶下劃線和不帶下劃線的區別是什麼?

Beego框架中NewFlash()函數如何實現頁面間短暫信息傳遞? Beego框架中NewFlash()函數如何實現頁面間短暫信息傳遞? Mar 03, 2025 pm 05:22 PM

Beego框架中NewFlash()函數如何實現頁面間短暫信息傳遞?

如何編寫模擬對象和存根以進行測試? 如何編寫模擬對象和存根以進行測試? Mar 10, 2025 pm 05:38 PM

如何編寫模擬對象和存根以進行測試?

如何使用跟踪工具了解GO應用程序的執行流? 如何使用跟踪工具了解GO應用程序的執行流? Mar 10, 2025 pm 05:36 PM

如何使用跟踪工具了解GO應用程序的執行流?

Go語言中如何將MySQL查詢結果List轉換為自定義結構體切片? Go語言中如何將MySQL查詢結果List轉換為自定義結構體切片? Mar 03, 2025 pm 05:18 PM

Go語言中如何將MySQL查詢結果List轉換為自定義結構體切片?

您如何在GO中編寫單元測試? 您如何在GO中編寫單元測試? Mar 21, 2025 pm 06:34 PM

您如何在GO中編寫單元測試?

Go語言如何便捷地寫入文件? Go語言如何便捷地寫入文件? Mar 03, 2025 pm 05:15 PM

Go語言如何便捷地寫入文件?

如何定義GO中仿製藥的自定義類型約束? 如何定義GO中仿製藥的自定義類型約束? Mar 10, 2025 pm 03:20 PM

如何定義GO中仿製藥的自定義類型約束?

See all articles