本文介绍: 在使用grom时,如果用结构体的形式,对数据库进行更新时,会出现一个问题:当我们想要将某个字段的值更新为0,执行update之后会发现该数据实际上并没有被更新。这种情况下,在update前加一个select操作,就可以正常更新了,具体实现如下。会发现,执行成功之后,score依然等于100,而不是我们要更新的0。当我们执行以下操作后。
在使用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)
原文地址:https://blog.csdn.net/typedef_struct/article/details/129873327
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_23732.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。