golang 目前在自带的 database 数据库操作包里面,如果事务 commit 失败,需不需要 rollback 回滚?

af913337456 · 2018-04-24 10:02:09 · 3067 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2018-04-24 10:02:09 的主题,其中的信息可能已经有所发展或是发生改变。

如题,golang 目前在自带的 database 数据库操作包里面,如果事务 commit 失败,需不需要 rollback 回滚?

例如

err := session.Commit()
if err != nil {
    session.Rollback()
    return util.GetCommonErr(err.Error())
}

有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

3067 次点击  
加入收藏 微博
5 回复  |  直到 2018-05-23 11:51:53
af913337456
af913337456 · #1 · 7年之前

交流下啊

jarlyyn
jarlyyn · #2 · 7年之前

需要,一般都加在defer里

找了段代码,大概是这样

tx, err := m.DB().Begin()
if err != nil {
    return err
}
defer tx.Rollback()

Update := query.NewUpdate(m.TableName())
Update.Update.AddFields(m.FieldsUpdate(f))

Update.Where.Condition = query.Equal("id", id)
_, err = Update.Query().Exec(tx)
if err != nil {
    return err
}
return tx.Commit()
mrfantuan
mrfantuan · #3 · 7年之前
jarlyynjarlyyn #2 回复

需要,一般都加在defer里 找了段代码,大概是这样 tx, err := m.DB().Begin() if err != nil { return err } defer tx.Rollback() Update := query.NewUpdate(m.TableName()) Update.Update.AddFields(m.FieldsUpdate(f)) Update.Where.Condition = query.Equal("id", id) _, err = Update.Query().Exec(tx) if err != nil { return err } return tx.Commit()

这样写的话岂不是,不管成不成功 都会 rollback

jarlyyn
jarlyyn · #4 · 7年之前
mrfantuanmrfantuan #3 回复

#2楼 @jarlyyn 这样写的话岂不是,不管成不成功 都会 rollback

A transaction must end with a call to Commit or Rollback.

After a call to Commit or Rollback, all operations on the transaction fail with ErrTxDone.

所以如果Commit过,rollback也不过是返回个err

ukinhappy
ukinhappy · #5 · 7年之前

oh

添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传