在使用grom时,如果用结构体的形式,对数据库进行更新时,会出现一个问题:当我们想要将某个字段的值更新为0,执行update之后会发现该数据实际上并没有被更新。
例如有如下数据表:
| id | name | score |
|---|---|---|
| 1 | zhangsan | 100 |
有如下结构体:
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)
在使用Gorm操作数据库时,如果尝试用结构体更新字段值为0,可能会遇到更新失败的问题。当尝试将score字段从100更新为0时,实际结果未变。解决方法是在update前添加一个select操作,明确指定需要更新的字段,如`Select(fields).Updates(Student)`,这样可以确保score字段正确更新为0。
1041

被折叠的 条评论
为什么被折叠?



