本文介绍: 在使用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进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注