Gorm 更新并在单个操作中获取更新的行?
短信预约 -IT技能 免费直播动态提醒
大家好,我们又见面了啊~本文《Gorm 更新并在单个操作中获取更新的行?》的内容中将会涉及到等等。如果你正在学习Golang相关知识,欢迎关注我,以后会给大家带来更多Golang相关文章,希望我们能一起进步!下面就开始本文的正式内容~
问题内容有没有办法通过一次操作来获取已使用 Gorm 中的更新命令更新的行。
解决方案
我知道这已经有一百万年了,但为了完成,这里是 gorm 的做法 - 子句。
result := r.gdb.model(&user{}).clauses(clause.returning{}).where("id = ?", "000-000-000").updates(content)
Ref: Gorm Returning Data From Modified Rows
这并不漂亮,但由于您使用的是 postgres,您可以执行以下操作:
realDB := db.DB()
rows, err := realDB.Query("UPDATE some_table SET name = 'a' WHERE name = 'b' RETUNING id, name")
//you could probably do db.Raw but I'm not sure
if err != nil {
log.Fatal(err)
}
defer rows.Close()
for rows.Next() {
var id int
var name string
err := rows.Scan(&id, &name)
if err != nil {
log.Fatal(err)
}
log.Println(id, name)
}
到这里,我们也就讲完了《Gorm 更新并在单个操作中获取更新的行?》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注编程网公众号,带你了解更多关于的知识点!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341