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
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)