登录
首页 >  Golang >  Go问答

何时提交go goose 事务?

来源:stackoverflow

时间:2024-03-12 15:27:29 153浏览 收藏

Golang不知道大家是否熟悉?今天我将给大家介绍《何时提交go goose 事务?》,这篇文章主要会讲到等等知识点,如果你在看完本篇文章后,有更好的建议或者发现哪里有问题,希望大家都能积极评论指出,谢谢!希望我们能一起加油进步!

问题内容

  • 我有一些代码需要在 tx 中运行,如下所示
  • 我生成了一个 go sql 迁移,如 go goose 的官方文档中所述

我的问题是:

  • 这些事务什么时候真正被 commited 到数据库?
  • 我强制使用 tx.commit() 提交迁移。这是我在 go 中的迁移文件:
func Up00002(tx *sql.Tx) error {
    _, err := tx.Exec("UPDATE users SET username='admin' WHERE username='root';")
    if err != nil {
        return err
    }

    if err = tx.Commit(); err != nil {
        return fmt.Errorf("error during committing the transaction: %w", err)
    }


    return nil
}

我无法在 down 部分之后运行上述迁移,因为当我运行它们时,我得到了 errtxdone (源)。我仍然想多次运行 go 迁移 up00002 (用于测试)。我怎样才能做到这一点?我在这里做错了什么?


正确答案


因此,只需浏览他们的文档此处即可显示提交已经在 AddMigrations 调用中发生 - 这是使用 ofc 事务,由 go goose 内部处理 - 非常好:)

对于sql也是如此,正如我们所看到的这里

pkg还提供了--no-transaction选项,我们可以使用它来完全控制db对象 - 太棒了!

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《何时提交go goose 事务?》文章吧,也可关注golang学习网公众号了解相关技术文章。

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