登录
首页 >  Golang >  Go问答

Gorm 更新并在单个操作中获取更新的行?

来源:stackoverflow

时间:2024-04-04 12:00:32 402浏览 收藏

大家好,我们又见面了啊~本文《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 更新并在单个操作中获取更新的行?》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>