首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用struct & mongodb/mongo-go-driver更新/替换mongodb文档

使用struct & mongodb/mongo-go-driver更新/替换mongodb文档
EN

Stack Overflow用户
提问于 2018-10-07 07:52:45
回答 2查看 9.5K关注 0票数 11

我正在尝试使用结构更新/替换mongodb文档,但我一直在获取err: update document must contain key beginning with '$'

代码语言:javascript
复制
collection := r.client.Database(database).Collection(greetingCollection)
payment.MongoID = objectid.New()
filter := bson.NewDocument(bson.EC.String("id", payment.ID))
_, err := collection.UpdateOne(ctx, filter, payment)
return err
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-10-07 20:08:48

应该将update语句而不是文档作为Collection.UpdateOne方法的第三个参数。例如:

代码语言:javascript
复制
update := bson.NewDocument(
    bson.EC.SubDocumentFromElements(
        "$set",
        bson.EC.Double("pi", 3.14159),
    ),
)
collection.UpdateOne(ctx, filter, update)

有关MongoDB docs中可用的更新操作符(键以‘$’开头)的更多信息,请参阅。

票数 6
EN

Stack Overflow用户

发布于 2020-03-31 16:09:45

我相信被接受的答案对我不起作用,因为我使用的是go.mongodb.org/mongo-driver包。使用这个包,语法甚至更简单:

代码语言:javascript
复制
update := bson.M{
        "$set": yourDocument,
    }

collection.UpdateOne(ctx, filter, update)
票数 16
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52684304

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档