mongodb无法在Go中执行事务,并且总是得到无法在多文档事务中创建名称空间

时间:2020-06-13 11:44:01

标签: mongodb go transactions

我正在尝试创建一个通过包装事务处理InsertOne数据的函数,并且我已经在mongodb中设置了副本,我在local和MongoDB地图集中尝试了错误相同的问题, 这是代码:

    const MONGODB_URI = "mongodb://localhost:27017,localhost:27018,localhost:27019/?replicaSet=rs"
    ctx := context.Background()
    client, err := mongo.Connect(ctx, options.Client().ApplyURI(MONGODB_URI))
    if err != nil {
        panic(err)
    }

    db := client.Database("production")
    defer db.Client().Disconnect(ctx)
    col := db.Collection("people")

    // transaction
    err = db.Client().UseSession(ctx, func(sessionContext mongo.SessionContext) error {
        err := sessionContext.StartTransaction()
        if err != nil {
            fmt.Println(err)
            return err
        }

        _, err = col.InsertOne(sessionContext, req)
        if err != nil {
            sessionContext.AbortTransaction(sessionContext)
            fmt.Println(err)
            return err
        } else {
            sessionContext.CommitTransaction(sessionContext)
        }
        return nil
    })

    if err != nil {
        return nil, err
    }

我已经按照this question in Stackoverflow的说明进行了操作,并且也尝试了从this article mongodb developer开始的方法

我得到的是这个错误:

(NamespaceNotFound) Cannot create namespace 
production.people in multi-document transaction.

multiple write errors: [{write errors: 
[{Cannot create namespace spura.people in multi-document transaction.}]},
 {<nil>}]"

插入数据时出现错误,代码中有问题吗?我尝试仔细查看并尝试使用文档或文章的说明,但始终收到该错误:(

1 个答案:

答案 0 :(得分:0)

MongoDB 4.2及更低版本does not permit creating collections in transactions。在4.4中取消了此限制。

对于4.2及更低版本,请提前create the collection