zvvq技术分享网

需要帮助从 mongodb 文档获取元素并使用 go mongo 驱

作者:zvvq博客网
导读php小编草莓在这里为大家介绍一种常见的需求:如何从MongoDB文档中获取元素并使用Go Mongo驱动程序更新其值。MongoDB是一种流行的NoSQL数据库,而Go是一种强大的编程语言,两者的结合可

php小编草莓在这里为大家介绍一种常见的需求:如何从MongoDB文档中获取元素并使用Go Mongo驱动程序更新其值。MongoDB是一种流行的NoSQL数据库,而Go是一种强大的编程语言,两者的结合可以带来很多好处。在本文中,我们将探讨如何使用Go Mongo驱动程序来实现这个需求,帮助您更好地理解和应用这个技术。 内容来自samhan

问题内容

内容来自zvvq,别采集哟

嘿,我正在使用 go.mongodb.org/mongo-driver 包来使用 golang。这是我的代码:

zvvq好,好zvvq

package src 本文来自zvvq

import (

本文来自zvvq

"context"

内容来自samhan666

"fmt" 本文来自zvvq

"log" 内容来自zvvq

"go.mongodb.org/mongo-driver/bson"

zvvq好,好zvvq

"go.mongodb.org/mongo-driver/mongo"

copyright zvvq

"go.mongodb.org/mongo-driver/mongo/options"

内容来自zvvq,别采集哟

)

内容来自samhan666

var ( zvvq

client mongo.client

内容来自samhan666

stickerscol mongo.collection 内容来自samhan

)

内容来自samhan666

func init() {

本文来自zvvq

log.println("setting up database...")

zvvq

var err error

内容来自zvvq,别采集哟

client, err = mongo.connect(context.background(), options.client().applyuri(envars.dburl))

copyright zvvq

if err != nil {

内容来自samhan666

log.fatal(err) zvvq.cn

}

本文来自zvvq

log.println("connected to database") zvvq

stickerscol = client.database("stickersbot").collection("stickers")

zvvq.cn

chatcol = client.database("stickersbot").collection("chat")

内容来自samhan666

}

内容来自samhan666

func changedefaultpack(userid int64, stickername string, format string) error { zvvq.cn

fmt.println(userid, stickername, format) 内容来自zvvq

filter := bson.m{

内容来自samhan

"_id": userid,

zvvq好,好zvvq

"stickers.stickername": stickername, 内容来自samhan666

"stickers.stickerpacktype": format, 内容来自samhan

} 内容来自zvvq

updateother := bson.m{

本文来自zvvq

"$set": bson.m{ 内容来自samhan

"stickers.$[elem].isdefault": false,

内容来自zvvq

}, 内容来自samhan

} copyright zvvq

update := bson.m{

本文来自zvvq

"$set": bson.m{

zvvq好,好zvvq

"stickers.$.isdefault": true, 内容来自zvvq,别采集哟

}, copyright zvvq

}

本文来自zvvq

arrayfilters := options.arrayfilters{

内容来自zvvq,别采集哟

filters: []interface{}{bson.m{"elem.stickerpacktype": format}}, zvvq

}

zvvq好,好zvvq

updateoptions := options.update().setarrayfilters(arrayfilters)

zvvq

_, err := stickerscol.updatemany(context.todo(), filter, updateother, updateoptions)

zvvq

if err != nil { 本文来自zvvq

return err 本文来自zvvq

}

本文来自zvvq

ok, err := stickerscol.updateone(context.background(), filter, update, options.update().setupsert(true)) 内容来自zvvq

if err != nil { zvvq

return err zvvq好,好zvvq

} 内容来自samhan666

if ok.modifiedcount == 0 {

内容来自zvvq

fmt.println("no document matched")

zvvq.cn

return fmt.errorf("no document matched")

copyright zvvq

}

zvvq

return err zvvq好,好zvvq

} 内容来自zvvq,别采集哟

zvvq好,好zvvq

这是数据库结构:

内容来自samhan666

... zvvq

{

本文来自zvvq

"_id": 1633375527, zvvq

"stickers": [ 内容来自samhan666

{ 内容来自zvvq,别采集哟

"stickerpacktype": "static", zvvq.cn

"stickername": "gVtOy_1633375527_by_ChadManBot",

copyright zvvq

"isdefault": true

内容来自samhan

},

zvvq.cn

{ 内容来自samhan666

"stickerpacktype": "animated",

内容来自zvvq

"stickername": "zIjsa_1633375527_by_ChadManBot",

内容来自samhan666

"isdefault": true 内容来自zvvq

}, 内容来自samhan

{

内容来自zvvq

"stickerpacktype": "video",

内容来自samhan

"stickername": "bJBle_1633375527_by_ChadManBot", 内容来自samhan

"isdefault": true copyright zvvq

},

内容来自zvvq,别采集哟

{ 内容来自zvvq,别采集哟

"stickerpacktype": "static", 内容来自samhan

"stickername": "iujiw_1633375527_by_ChadManBot",

内容来自samhan

"isdefault": false

内容来自zvvq,别采集哟

},

内容来自zvvq

{ 内容来自samhan

"stickerpacktype": "video",

zvvq好,好zvvq

"stickername": "CHnqb_1633375527_by_ChadManBot",

内容来自samhan

"isdefault": false

内容来自samhan

},

本文来自zvvq

{ zvvq.cn

"stickerpacktype": "static", copyright zvvq

"stickername": "XKJUP_1633375527_by_ChadManBot", zvvq

"isdefault": false 内容来自samhan666

}, 内容来自zvvq,别采集哟

{

zvvq

"stickerpacktype": "animated", 内容来自samhan666

"stickername": "pCFlC_1633375527_by_ChadManBot",

内容来自zvvq

"isdefault": false

本文来自zvvq

}, zvvq好,好zvvq

{

zvvq.cn

"stickerpacktype": "animated", 内容来自zvvq,别采集哟

"stickername": "jGGgt_1633375527_by_ChadManBot",

内容来自samhan

"isdefault": false copyright zvvq

}, 内容来自zvvq,别采集哟

{ 内容来自zvvq,别采集哟

"stickerpacktype": "animated", 内容来自zvvq

"stickername": "cTxyA_1633375527_by_ChadManBot",

内容来自samhan

"isdefault": false

内容来自samhan666

},

内容来自zvvq

{

zvvq

"stickerpacktype": "animated", 内容来自samhan

"stickername": "ZfYXO_1633375527_by_ChadManBot",

zvvq.cn

"isdefault": false 内容来自samhan

},

内容来自zvvq,别采集哟

{

zvvq好,好zvvq

"stickerpacktype": "static",

zvvq.cn

"stickername": "xJUkA_1633375527_by_ChadManBot", 本文来自zvvq

"isdefault": false

本文来自zvvq

}, 内容来自zvvq

{

内容来自zvvq

"stickerpacktype": "static",

zvvq.cn

"stickername": "HIvsY_1633375527_by_ChadManBot",

内容来自samhan666

"isdefault": false

zvvq好,好zvvq

},

内容来自samhan666

{ 内容来自zvvq,别采集哟

"stickerpacktype": "static", zvvq.cn

"stickername": "WIHFQ_1633375527_by_ChadManBot", zvvq

"isdefault": false

本文来自zvvq

}, 内容来自zvvq

{ copyright zvvq

"stickerpacktype": "static", 内容来自zvvq,别采集哟

"stickername": "OqjtE_1633375527_by_ChadManBot",

内容来自zvvq,别采集哟

"isdefault": false zvvq.cn

}, 内容来自zvvq

{

内容来自samhan

"stickerpacktype": "static", 内容来自zvvq,别采集哟

"stickername": "QNysO_1633375527_by_ChadManBot",

内容来自samhan666

"isdefault": false

内容来自zvvq

}, copyright zvvq

{ 本文来自zvvq

"stickerpacktype": "static", 内容来自zvvq

"stickername": "OrTsT_1633375527_by_ChadManBot",

内容来自samhan

"isdefault": false 内容来自samhan666

},

zvvq

{ 内容来自samhan

"stickerpacktype": "static", 内容来自samhan666

"stickername": "FzROg_1633375527_by_ChadManBot", zvvq

"isdefault": false

copyright zvvq

},

zvvq好,好zvvq

{

zvvq

"stickerpacktype": "static",

zvvq好,好zvvq

"stickername": "QUBcT_1633375527_by_ChadManBot",

内容来自samhan

"isdefault": false copyright zvvq

}, 内容来自zvvq,别采集哟

{

zvvq好,好zvvq

"stickerpacktype": "static",

zvvq

"stickername": "NsZfM_1633375527_by_ChadManBot", 内容来自zvvq

"isdefault": false

内容来自zvvq,别采集哟

},

内容来自samhan

{ 本文来自zvvq

"stickerpacktype": "static", 内容来自samhan

"stickername": "AkxVM_1633375527_by_ChadManBot", 内容来自samhan

"isdefault": false 内容来自samhan

},

zvvq

{ 内容来自zvvq

"stickerpacktype": "static",

本文来自zvvq

"stickername": "Ddvus_1633375527_by_ChadManBot",

zvvq.cn

"isdefault": false zvvq.cn

},

本文来自zvvq

{

copyright zvvq

"stickerpacktype": "static",

本文来自zvvq

"stickername": "LXfHV_1633375527_by_ChadManBot", zvvq好,好zvvq

"isdefault": false zvvq

}, 内容来自samhan666

{ zvvq好,好zvvq

"stickerpacktype": "static",

本文来自zvvq

"stickername": "sTaMv_1633375527_by_ChadManBot", zvvq

"isdefault": false zvvq

}, zvvq好,好zvvq

{ 内容来自samhan

"stickerpacktype": "static",

内容来自zvvq,别采集哟

"stickername": "vppgK_1633375527_by_ChadManBot",

内容来自samhan666

"isdefault": false 内容来自zvvq,别采集哟

}

zvvq.cn

],

本文来自zvvq

"stickerpackcount": 2 内容来自zvvq

}

zvvq.cn

... 内容来自samhan

copyright zvvq

我需要我的代码是找到与给定 id 和贴纸类型匹配的贴纸包列表,并将其默认值设置为 false 并将传递给 func 的包的默认值设置为 true。

zvvq.cn

基本上只是将其中一个设置为默认值,将其他设置为非默认值。有人可以解释一下为什么这个函数返回未找到文档吗?

内容来自samhan

点击下载“电脑DLL修复工具”; zvvq好,好zvvq

解决方法 zvvq好,好zvvq

当有多个字段匹配时,您应该使用 $elemmatch 运算符。否则,$ 运算符不起作用。请参阅 使用多个字段匹配更新嵌入文档。 内容来自zvvq,别采集哟

并且您不需要 updatemany 来更新单个文档中的多个数组元素。请改用 updateone。

内容来自samhan

这是基于您的代码和数据的演示:

copyright zvvq

package main 内容来自zvvq

import ( 内容来自samhan666

"context" zvvq.cn

"fmt" zvvq

"log" 本文来自zvvq

"go.mongodb.org/mongo-driver/bson"

本文来自zvvq

"go.mongodb.org/mongo-driver/mongo" 内容来自zvvq,别采集哟

"go.mongodb.org/mongo-driver/mongo/options"

内容来自zvvq,别采集哟

)

zvvq.cn

var (

zvvq好,好zvvq

client mongo.client 内容来自samhan

stickerscol mongo.collection

copyright zvvq

)

内容来自samhan

func init() { 内容来自zvvq

log.println("setting up database...") zvvq.cn

var err error

zvvq好,好zvvq

client, err = mongo.connect(context.background(), options.client().applyuri("mongodb://localhost"))

内容来自samhan666

if err != nil { 内容来自zvvq,别采集哟

log.fatal(err) zvvq

}

copyright zvvq

log.println("connected to database")

zvvq

stickerscol = client.database("stickersbot").collection("stickers")

zvvq

}

copyright zvvq

func changedefaultpack(userid int64, stickername string, format string) error { zvvq好,好zvvq

fmt.println(userid, stickername, format)

本文来自zvvq

filter := bson.m{ zvvq

"_id": userid,

zvvq好,好zvvq

"stickers": bson.m{

内容来自zvvq,别采集哟

"$elemmatch": bson.m{

内容来自samhan

"stickername": stickername,

内容来自zvvq

"stickerpacktype": format, 内容来自zvvq,别采集哟

}, copyright zvvq

}, copyright zvvq

} zvvq

updateother := bson.m{

内容来自samhan

"$set": bson.m{

内容来自samhan666

"stickers.$[elem].isdefault": false, 内容来自samhan

}, 内容来自zvvq

}

内容来自samhan

arrayfilters := options.arrayfilters{

内容来自samhan

filters: []interface{}{bson.m{"elem.stickerpacktype": format}}, copyright zvvq

}

zvvq好,好zvvq

updateoptions := options.update().setarrayfilters(arrayfilters)

内容来自samhan

result, err := stickerscol.updateone(context.background(), filter, updateother, updateoptions) copyright zvvq

if err != nil {

本文来自zvvq

return err

内容来自samhan

}

copyright zvvq

log.printf("update other: %+v ", result) zvvq

update := bson.m{

内容来自zvvq,别采集哟

"$set": bson.m{

内容来自samhan666

"stickers.$.isdefault": true, zvvq好,好zvvq

}, 本文来自zvvq

} 内容来自samhan666

ok, err := stickerscol.updateone(context.background(), filter, update, options.update().setupsert(true)) 内容来自samhan666

if err != nil { zvvq好,好zvvq

return err 本文来自zvvq

}

内容来自samhan666

log.printf("update default: %+v ", ok)

内容来自zvvq,别采集哟

if ok.modifiedcount == 0 { zvvq.cn

fmt.println("no document matched")

zvvq

return fmt.errorf("no document matched") 内容来自zvvq,别采集哟

} 内容来自samhan

return err zvvq.cn

}

内容来自samhan

func main() {

内容来自samhan

if err := changedefaultpack(1633375527, "ddvus_1633375527_by_chadmanbot", "static"); err != nil { zvvq好,好zvvq

panic(err)

zvvq.cn

}

本文来自zvvq

}

内容来自samhan

本文来自zvvq

运行演示,您将观察到文档发生以下更改:

内容来自samhan

--- before.json 2023-06-27 00:34:32.721978745 +0800

内容来自samhan

after.json 2023-06-27 00:34:59.489836137 +0800

内容来自samhan666

@@ -4,7 +4,7 @@ 内容来自samhan

{

内容来自zvvq,别采集哟

"stickerpacktype": "static",

内容来自samhan

"stickername": "gVtOy_1633375527_by_ChadManBot",

内容来自samhan

- "isdefault": true

zvvq.cn

+ "isdefault": false copyright zvvq

}, copyright zvvq

{

内容来自zvvq

"stickerpacktype": "animated",

本文来自zvvq

@@ -104,7 +104,7 @@ zvvq.cn

{

copyright zvvq

"stickerpacktype": "static", zvvq.cn

"stickername": "Ddvus_1633375527_by_ChadManBot", 内容来自zvvq,别采集哟

- "isdefault": false zvvq.cn

+ "isdefault": true

zvvq.cn

}, zvvq.cn

{

zvvq

"stickerpacktype": "static", 本文来自zvvq

内容来自zvvq,别采集哟

以上就是需要帮助从 mongodb 文档获取元素并使用 go mongo 驱动程序更新其值的详细内容,更多请关注其它相关文章! 本文来自zvvq