在使用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)