php小编草莓在这里为大家介绍一种常见的需求:如何从MongoDB文档中获取元素并使用Go Mongo驱动程序更新其值。MongoDB是一种流行的NoSQL数据库,而Go是一种强大的编程语言,两者的结合可以带来很多好处。在本文中,我们将探讨如何使用Go Mongo驱动程序来实现这个需求,帮助您更好地理解和应用这个技术。 本文来自zvvq
问题内容
内容来自zvvq,别采集哟
嘿,我正在使用 go.mongodb.org/mongo-driver 包来使用 golang。这是我的代码:
内容来自samhan666
package src copyright zvvq
import (
zvvq.cn
"context" 本文来自zvvq
"fmt" zvvq
"log" 内容来自zvvq,别采集哟
"go.mongodb.org/mongo-driver/bson" 内容来自samhan
"go.mongodb.org/mongo-driver/mongo" 本文来自zvvq
"go.mongodb.org/mongo-driver/mongo/options" 内容来自zvvq
) 内容来自zvvq
var ( copyright zvvq
client *mongo.client
stickerscol *mongo.collection
内容来自samhan
)
内容来自zvvq
func init() { 内容来自samhan
log.println("setting up database...")
var err error
zvvq
client, err = mongo.connect(context.background(), options.client().applyuri(envars.dburl))
if err != nil {
内容来自zvvq,别采集哟
log.fatal(err)
内容来自zvvq,别采集哟
} 本文来自zvvq
log.println("connected to database")
本文来自zvvq
stickerscol = client.database("stickersbot").collection("stickers") 内容来自zvvq
chatcol = client.database("stickersbot").collection("chat") zvvq
}
内容来自zvvq
func changedefaultpack(userid int64, stickername string, format string) error { 本文来自zvvq
fmt.println(userid, stickername, format)
filter := bson.m{ 内容来自samhan
"_id": userid,
"stickers.stickername": stickername, 内容来自samhan666
"stickers.stickerpacktype": format, zvvq.cn
}
copyright zvvq
updateother := bson.m{ zvvq.cn
"$set": bson.m{
"stickers.$[elem].isdefault": false, copyright zvvq
}, 内容来自samhan
}
copyright zvvq
update := bson.m{ 内容来自zvvq,别采集哟
"$set": bson.m{ 内容来自samhan
"stickers.$.isdefault": true,
}, zvvq好,好zvvq
}
zvvq好,好zvvq
arrayfilters := options.arrayfilters{
filters: []interface{}{bson.m{"elem.stickerpacktype": format}}, 内容来自zvvq,别采集哟
}
updateoptions := options.update().setarrayfilters(arrayfilters)
zvvq.cn
_, err := stickerscol.updatemany(context.todo(), filter, updateother, updateoptions) zvvq
if err != nil { zvvq好,好zvvq
return err 本文来自zvvq
}
ok, err := stickerscol.updateone(context.background(), filter, update, options.update().setupsert(true))
zvvq好,好zvvq
if err != nil {
return err
}
if ok.modifiedcount == 0 { 内容来自samhan666
fmt.println("no document matched")
return fmt.errorf("no document matched")
} zvvq好,好zvvq
return err
} 本文来自zvvq
这是数据库结构:
内容来自samhan
... zvvq
{ 内容来自samhan666
"_id": 1633375527,
内容来自zvvq,别采集哟
"stickers": [
{
zvvq好,好zvvq
"stickerpacktype": "static",
"stickername": "gVtOy_1633375527_by_ChadManBot",
"isdefault": true 内容来自samhan666
}, 内容来自samhan666
{
本文来自zvvq
"stickerpacktype": "animated", 本文来自zvvq
"stickername": "zIjsa_1633375527_by_ChadManBot",
copyright zvvq
"isdefault": true zvvq.cn
}, 本文来自zvvq
{
"stickerpacktype": "video", 内容来自zvvq
"stickername": "bJBle_1633375527_by_ChadManBot", zvvq
"isdefault": true 本文来自zvvq
}, copyright zvvq
{ 内容来自samhan666
"stickerpacktype": "static", 内容来自zvvq
"stickername": "iujiw_1633375527_by_ChadManBot",
zvvq好,好zvvq
"isdefault": false
}, copyright zvvq
{ 内容来自zvvq
"stickerpacktype": "video", 内容来自zvvq
"stickername": "CHnqb_1633375527_by_ChadManBot",
copyright zvvq
"isdefault": false 内容来自zvvq,别采集哟
}, 内容来自zvvq,别采集哟
{
"stickerpacktype": "static",
内容来自zvvq,别采集哟
"stickername": "XKJUP_1633375527_by_ChadManBot", 内容来自zvvq,别采集哟
"isdefault": false
}, zvvq.cn
{
内容来自zvvq,别采集哟
"stickerpacktype": "animated",
本文来自zvvq
"stickername": "pCFlC_1633375527_by_ChadManBot",
zvvq.cn
"isdefault": false
},
{
"stickerpacktype": "animated",
zvvq好,好zvvq
"stickername": "jGGgt_1633375527_by_ChadManBot",
"isdefault": false
zvvq
}, 本文来自zvvq
{ copyright zvvq
"stickerpacktype": "animated",
"stickername": "cTxyA_1633375527_by_ChadManBot", zvvq好,好zvvq
"isdefault": false
内容来自samhan666
}, copyright zvvq
{
"stickerpacktype": "animated",
内容来自samhan
"stickername": "ZfYXO_1633375527_by_ChadManBot",
内容来自samhan666
"isdefault": false zvvq
}, 内容来自samhan666
{ 内容来自samhan
"stickerpacktype": "static", 内容来自zvvq
"stickername": "xJUkA_1633375527_by_ChadManBot",
"isdefault": false
zvvq.cn
},
内容来自samhan
{ zvvq
"stickerpacktype": "static", zvvq
"stickername": "HIvsY_1633375527_by_ChadManBot", 内容来自zvvq
"isdefault": false 内容来自samhan
},
zvvq.cn
{ zvvq好,好zvvq
"stickerpacktype": "static",
内容来自zvvq,别采集哟
"stickername": "WIHFQ_1633375527_by_ChadManBot", 内容来自samhan666
"isdefault": false 内容来自zvvq,别采集哟
}, copyright zvvq
{
本文来自zvvq
"stickerpacktype": "static", 本文来自zvvq
"stickername": "OqjtE_1633375527_by_ChadManBot", 内容来自samhan
"isdefault": false 内容来自samhan
}, 内容来自zvvq
{ zvvq
"stickerpacktype": "static", zvvq
"stickername": "QNysO_1633375527_by_ChadManBot",
"isdefault": false 内容来自samhan666
}, 内容来自zvvq
{
"stickerpacktype": "static", 内容来自zvvq
"stickername": "OrTsT_1633375527_by_ChadManBot",
"isdefault": false 内容来自samhan666
},
{
"stickerpacktype": "static",
"stickername": "FzROg_1633375527_by_ChadManBot", zvvq
"isdefault": false
内容来自zvvq
},
{ 内容来自zvvq
"stickerpacktype": "static", copyright zvvq
"stickername": "QUBcT_1633375527_by_ChadManBot",
内容来自zvvq
"isdefault": false zvvq.cn
}, 内容来自zvvq
{ 内容来自zvvq,别采集哟
"stickerpacktype": "static",
"stickername": "NsZfM_1633375527_by_ChadManBot", copyright zvvq
"isdefault": false 本文来自zvvq
},
{
内容来自zvvq
"stickerpacktype": "static",
"stickername": "AkxVM_1633375527_by_ChadManBot",
"isdefault": false
},
zvvq
{
"stickerpacktype": "static",
zvvq
"stickername": "Ddvus_1633375527_by_ChadManBot", 内容来自zvvq
"isdefault": false 内容来自samhan666
},
内容来自zvvq,别采集哟
{ copyright zvvq
"stickerpacktype": "static", copyright zvvq
"stickername": "LXfHV_1633375527_by_ChadManBot", zvvq
"isdefault": false copyright zvvq
}, zvvq
{
"stickerpacktype": "static", copyright zvvq
"stickername": "sTaMv_1633375527_by_ChadManBot", zvvq
"isdefault": false zvvq好,好zvvq
}, zvvq
{ zvvq
"stickerpacktype": "static",
"stickername": "vppgK_1633375527_by_ChadManBot",
"isdefault": false 内容来自samhan666
} 本文来自zvvq
],
"stickerpackcount": 2
zvvq
} 内容来自samhan
...
我需要我的代码是找到与给定 id 和贴纸类型匹配的贴纸包列表,并将其默认值设置为 false 并将传递给 func 的包的默认值设置为 true。
内容来自zvvq
基本上只是将其中一个设置为默认值,将其他设置为非默认值。有人可以解释一下为什么这个函数返回未找到文档吗?
内容来自zvvq,别采集哟
点击下载“电脑DLL修复工具”; 内容来自zvvq
解决方法
内容来自samhan666
当有多个字段匹配时,您应该使用 $elemmatch 运算符。否则,$ 运算符不起作用。请参阅 使用多个字段匹配更新嵌入文档。
并且您不需要 updatemany 来更新单个文档中的多个数组元素。请改用 updateone。 zvvq好,好zvvq
这是基于您的代码和数据的演示:
package main
import ( zvvq.cn
"context"
本文来自zvvq
"fmt" 内容来自zvvq
"log"
copyright zvvq
"go.mongodb.org/mongo-driver/bson" 本文来自zvvq
"go.mongodb.org/mongo-driver/mongo"
内容来自zvvq
"go.mongodb.org/mongo-driver/mongo/options" 内容来自samhan
) zvvq
var (
client *mongo.client
stickerscol *mongo.collection 内容来自samhan
)
func init() { zvvq好,好zvvq
log.println("setting up database...") copyright zvvq
var err error 内容来自zvvq,别采集哟
client, err = mongo.connect(context.background(), options.client().applyuri("mongodb://localhost")) 内容来自samhan666
if err != nil { zvvq好,好zvvq
log.fatal(err)
}
内容来自zvvq,别采集哟
log.println("connected to database") 内容来自zvvq
stickerscol = client.database("stickersbot").collection("stickers")
内容来自zvvq,别采集哟
} 内容来自samhan666
func changedefaultpack(userid int64, stickername string, format string) error { zvvq
fmt.println(userid, stickername, format)
filter := bson.m{ zvvq.cn
"_id": userid,
内容来自zvvq
"stickers": bson.m{
"$elemmatch": bson.m{
内容来自samhan666
"stickername": stickername,
"stickerpacktype": format,
内容来自samhan
},
内容来自zvvq,别采集哟
}, zvvq.cn
} zvvq.cn
updateother := bson.m{
zvvq.cn
"$set": bson.m{
"stickers.$[elem].isdefault": false, 内容来自zvvq,别采集哟
},
}
arrayfilters := options.arrayfilters{ 内容来自samhan666
filters: []interface{}{bson.m{"elem.stickerpacktype": format}},
}
updateoptions := options.update().setarrayfilters(arrayfilters)
copyright zvvq
result, err := stickerscol.updateone(context.background(), filter, updateother, updateoptions) zvvq
if err != nil {
return err 内容来自zvvq,别采集哟
}
log.printf("update other: %+v ", result)
update := bson.m{ 内容来自samhan
"$set": bson.m{
"stickers.$.isdefault": true, 内容来自zvvq,别采集哟
}, 内容来自zvvq
}
ok, err := stickerscol.updateone(context.background(), filter, update, options.update().setupsert(true)) zvvq.cn
if err != nil {
return err 内容来自zvvq,别采集哟
}
copyright zvvq
log.printf("update default: %+v ", ok)
内容来自samhan
if ok.modifiedcount == 0 {
内容来自zvvq
fmt.println("no document matched")
return fmt.errorf("no document matched")
}
zvvq
return err zvvq
} zvvq好,好zvvq
func main() { 内容来自samhan
if err := changedefaultpack(1633375527, "ddvus_1633375527_by_chadmanbot", "static"); err != nil {
zvvq
panic(err)
}
copyright zvvq
}
copyright zvvq
内容来自samhan666
运行演示,您将观察到文档发生以下更改:
内容来自zvvq
--- before.json 2023-06-27 00:34:32.721978745 +0800
after.json 2023-06-27 00:34:59.489836137 +0800 内容来自samhan
@@ -4,7 +4,7 @@ zvvq好,好zvvq
{ 内容来自samhan
"stickerpacktype": "static",
zvvq好,好zvvq
"stickername": "gVtOy_1633375527_by_ChadManBot", zvvq
- "isdefault": true
本文来自zvvq
+ "isdefault": false copyright zvvq
}, 本文来自zvvq
{ 内容来自samhan666
"stickerpacktype": "animated", 内容来自samhan
@@ -104,7 +104,7 @@
{
"stickerpacktype": "static", 本文来自zvvq
"stickername": "Ddvus_1633375527_by_ChadManBot",
- "isdefault": false 内容来自samhan666
+ "isdefault": true
}, zvvq.cn
{
zvvq
"stickerpacktype": "static",
zvvq好,好zvvq
zvvq.cn
以上就是需要帮助从 mongodb 文档获取元素并使用 go mongo 驱动程序更新其值的详细内容,更多请关注其它相关文章!