当gorm更新的字段内容是0值时,不会更新的一种解决办法

在使用Gorm操作数据库时,如果尝试用结构体更新字段值为0,可能会遇到更新失败的问题。当尝试将score字段从100更新为0时,实际结果未变。解决方法是在update前添加一个select操作,明确指定需要更新的字段,如`Select(fields).Updates(Student)`,这样可以确保score字段正确更新为0。
摘要由CSDN通过智能技术生成

在使用grom时,如果用结构体的形式,对数据库进行更新时,会出现一个问题:当我们想要将某个字段的值更新为0,执行update之后会发现该数据实际上并没有被更新。
例如有如下数据表:

idnamescore
1zhangsan100

有如下结构体:

type Student struct{
	Id    int32 `gorm:"type:int(11);column:id;primaryKey;autoIncrement;comment:" json:"id"`
	Name  string `gorm:"type:varchar(100);column:name;not null;default:'';comment:姓名"`
	Score int32 `gorm:"type:int(11);column:score;comment:分数"`
}

当我们执行以下操作后

upStudent := Student{
	Id    :1
	name  :zhangsan
	score :0
}

db.Model(&student).Where("id=?", Student.Id).Updates(Student)

会发现,执行成功之后,score依然等于100,而不是我们要更新的0

这种情况下,在update前加一个select操作,就可以正常更新了,具体实现如下

fields := []string{"id","name","score"}
db.Model(&student).Select(fields).Where("id=?", Student.Id).Updates(Student)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值