登录
首页 >  Golang >  Go问答

更新数据后检索 GORM

来源:stackoverflow

时间:2024-02-22 08:06:21 105浏览 收藏

偷偷努力,悄无声息地变强,然后惊艳所有人!哈哈,小伙伴们又来学习啦~今天我将给大家介绍《更新数据后检索 GORM》,这篇文章主要会讲到等等知识点,不知道大家对其都有多少了解,下面我们就一起来看一吧!当然,非常希望大家能多多评论,给出合理的建议,我们一起学习,一起进步!

问题内容

我想在从记录返回字段的同时更新记录。如果我没有在同一命令中返回,则可能会出现并发问题,这就是我希望它成为原子操作的原因。有人可以指导我如何在 Gorm 中实现这一目标吗?


解决方案


您可以使用 func (*db) begintx 来启动事务,当您完成计算或更新时,您可以使用 func (s *db) commit() *db 来更新事务。它将锁定表以确保原子操作(如果发生错误,请使用回滚)。

有关此功能的更多信息,请使用此链接: https://godoc.org/github.com/jinzhu/gorm#DB.BeginTx

例如(示例 golang 代码):

db, err := mysql.SharedStore().BeginTx()
    if err != nil {
        return nil, err
    }
    defer func() { _ = db.Rollback() }()
    //calculations
    db.CommitTx()

终于介绍完啦!小伙伴们,这篇关于《更新数据后检索 GORM》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

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