【问题标题】:Example for transactions in mongodb with GoLang使用 GoLang 的 mongodb 中的事务示例
【发布时间】:2019-01-28 09:08:23
【问题描述】:

我需要一个使用 GoLang 在 MongoDB 中实现事务的示例。

我正在为 mongodb 使用这个 golang 驱动程序

https://github.com/mongodb/mongo-go-driver

没有关于如何实现交易的明确文档。

谁能帮帮我?

【问题讨论】:

    标签: mongodb go transactions


    【解决方案1】:

    这可能会令人困惑。下面是一个简单的例子。

    if session, err = client.StartSession(); err != nil {
        t.Fatal(err)
    }
    if err = session.StartTransaction(); err != nil {
        t.Fatal(err)
    }
    if err = mongo.WithSession(ctx, session, func(sc mongo.SessionContext) error {
        if result, err = collection.UpdateOne(sc, bson.M{"_id": id}, update); err != nil {
            t.Fatal(err)
        }
        if result.MatchedCount != 1 || result.ModifiedCount != 1 {
            t.Fatal("replace failed, expected 1 but got", result.MatchedCount)
        }
    
        if err = session.CommitTransaction(sc); err != nil {
            t.Fatal(err)
        }
        return nil
    }); err != nil {
        t.Fatal(err)
    }
    session.EndSession(ctx)
    

    您可以查看完整的examples here

    【讨论】:

    【解决方案2】:

    这对你有帮助

    ctx := context.Background()
    client, err := mongo.Connect(ctx, options.Client().ApplyURI("mongodb://localhost:27017"))
    if err != nil {
        panic(err)
    }
    
    db := client.Database("testdb")
    defer db.Client().Disconnect(ctx)
    col := db.Collection("testcol")
    
    // transaction
    err = db.Client().UseSession(ctx, func(sessionContext mongo.SessionContext) error {
        err := sessionContext.StartTransaction()
        if err != nil {
            return err
        }
    
        _, err = col.InsertOne(sessionContext, bson.M{"_id": "1", "name": "berry"})
        if err != nil {
            return err
        }
    
        _, err = col.InsertOne(sessionContext, bson.M{"_id": "2", "name": "gucci"})
        if err != nil {
            sessionContext.AbortTransaction(sessionContext)
            return err
        }
        if err = session.CommitTransaction(sessionContext); err != nil {
            return err
        }
        return nil
    })
    

    【讨论】:

    • 为什么你只在第二次操作失败时中止事务,为什么在第一次操作抛出错误时也不中止? @berryberry
    • 我同意你的观点@AayushTaneja,但是我们每次与数据库交互时都必须使用if else 子句,或者我们只需要在最后一行使用CommitTransaction?我想我们只需要在最后一行CommitTransaction。请纠正我
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-05-25
    • 1970-01-01
    • 2015-11-13
    • 2013-02-04
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多