gorm Save函数 使用注意点

Save() 函数 — 替换 或者创建
根据where条件和传入结构体的主键进行查找
没有查找到,就会创建记录
查找到就会更新记录
如果结构体对应字段没有被赋值,在更新,或者创建时 ,就会以对应字段就会以零值更新或创建记录。

type User struct {
	Id   string `json:"id"`
	Name string `json:"name"`
	Age  string `json:"age"`
}
dao.DB.AutoMigrate(&User{})
var user User
dao.DB.First(&user)
fmt.Println(user)
user.Age = "" 设置零值
dao.DB.Save(&user)更新成功
dao.DB.First(&user)
fmt.Println(user)

	user.Id = "0"
	user.Age = "1"
	dao.DB.Debug().Where("name=?", "10").Save(&user) // where name = "10" and id = "1" set user

建议先使用查询语句查询到结果之后再对查询到的结果对象进行修改赋值,最后使用Save保存操作。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值