最近在使用GORM时,我发现一个问题——外键未更新的情况。当我在关联的表中更新了外键字段的值时,却没有同步更新到另一张表中。通过调查和研究,我发现这是因为GORM默认情况下不会自动更新外键字段。这个问题困扰了我一段时间,所以我决定将解决方法分享给大家。在本文中,我将向大家介绍如何使用GORM来正确更新外键字段,以避免出现这个问题。
我有两张桌子,一张是公司
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
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 的值
更新插入完成后,每次都会插入新行。这是我们正在使用的代码
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
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中文网其他相关文章!