如何使用 GORM 创建或更新记录?

新手上路,请多包涵

Gorm 有一个 FirstOrCreate 方法和一个 FirstOrInit 但如何检查记录是否实际创建?如果记录不存在,我想创建一条记录,如果存在,我想更新一些字段。

原文由 Tarion 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 2.6k
2 个回答

更新2020.10.09

感谢 @vaelin

从 1.20.x 开始,GORM 为不同的数据库提供兼容的 Upsert 支持( Upsert-On-Conflict

 // Update columns to new value on `id` conflict
DB.Clauses(clause.OnConflict{
  Columns:   []clause.Column{{Name: "id"}}, // key colume
  DoUpdates: clause.AssignmentColumns([]string{"name", "age"}), // column needed to be updated
}).Create(&users)
// MERGE INTO "users" USING *** WHEN NOT MATCHED THEN INSERT *** WHEN MATCHED THEN UPDATE SET "name"="excluded"."name"; SQL Server
// INSERT INTO "users" *** ON CONFLICT ("id") DO UPDATE SET "name"="excluded"."name", "age"="excluded"."age"; PostgreSQL
// INSERT INTO `users` *** ON DUPLICATE KEY UPDATE `name`=VALUES(name),`age=VALUES(age); MySQL

对于 gorm 1.9.x 或以下版本,先更新更有效,然后在不存在时插入。

 // update only set name=nick
if err := db.Model(&newUser).Where("id = ?", 3333).Update("name", "nick").Error; err != nil {
    // always handle error like this, cause errors maybe happened when connection failed or something.
    // record not found...
    if gorm.IsRecordNotFoundError(err){
        db.Create(&newUser)  // create new record from newUser
    }
}

FirstOrInitFirstOrCreate 是不同的。如果数据库中没有匹配记录, FirstOrInit 将初始化结构但不创建记录, FirstOrCreate 将创建一个记录并查询该记录以构建。

原文由 Billy Yuan 发布,翻译遵循 CC BY-SA 4.0 许可协议

投票最多的答案对我不起作用,但这确实有效:

 user := NewUser(email, password)
if db.Model(&user).Where("email = ?", email).Updates(&user).RowsAffected == 0 {
    db.Create(&user)
}

这适用于 gorm v1.9.15 和 go 1.13

原文由 nobody 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
logo
Stack Overflow 翻译
子站问答
访问
宣传栏