gorm框架存在插入,存在则更新处理

gorm框架存在插入,存在则更新处理,第1张

一、gorm库

github地址:https://github.com/go-gorm/gorm
使用说明:https://gorm.io/docs/

二、探索

gorm支持clause来实现Upsert的功能,但是发现只支持根据id进行判断,如果对应id记录存在则更新,对应id记录不存在则插入。如下:

dbtable.Clauses(clause.OnConflict{
	Columns:   []clause.Column{{Name: "id"}},
	DoUpdates: clause.AssignmentColumns([]string{"remark", "is_delete"}),
}).Create(friend)

我用的数据库是mysql,需要根据userId和friendId作为条件进行更新,userId和friendId设置了联合唯一索引,用这个方式无法实现。

三、最终解决方案

先查询是否存在,不存在则插入,存在则更新,如下:

var friend FriendInfo
results := db.Table(tableName).Where("user_id = ? and friend_id = ?", uid, friend).First(&friend)
if results.Error != nil {
	if results.Error == gorm.ErrRecordNotFound {
		results := db.Table(tableName).Create(&friend)
		if results.Error != nil {
			return results.Error
		}
	} 
} else {
		friend.ID = friendRec.ID
		results := db.Table(tableName).Model(friend).Updates(map[string]interface{}{"friend_type": friend.FriendType, "remark": friend.FriendRemark, "is_delete": friend.IsDelete, "create_time": friend.CreateTime, "update_time": friend.UpdateTime})
		if results.Error != nil {
			return results.Error
		}
}

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/990974.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-21
下一篇 2022-05-21

发表评论

登录后才能评论

评论列表(0条)

保存