草庐IT

mongodb - MongoDB高级聚合

全部标签

mongodb - 构建包含字符串和正则表达式模式的 $in 数组

我有一个Mongo集合,集合中的每个文档都有一个sources数组属性。对此属性的搜索可以是精确匹配和正则表达式的组合。例如,当使用Mongoshell时,下面的查询搜索source='gasvalves'OR'hose'包含在源项中的文档。这和我预期的一样有效db.notice.find({sources:{$in:[/\bhose/i,'gasvalves']}})mgo中的事情变得有点棘手。因为$in数组中的某些项目可以是正则表达式,而其他项目是字符串-我想进行查询的唯一方法是使用$or:varregEx[]bson.RegExvarmatches[]string//dostuf

mongodb - mongo-go-driver 投影数组长度

我正在尝试对文档数组中的元素数量进行预测。options.SetProjection(bson.M{"foo":true,"nrOfBars":bson.M{"$size":"$bars"},})bars是数组的字段名。尽管此查询始终返回0而不是数组长度。如何使用新的mongo-go-driver正确查询数组的长度? 最佳答案 您正在尝试使用聚合运算符作为投影文档的一部分。projectiondocument用于简单查询以仅返回某些字段。您要使用的是aggregationpipeline中的$project阶段。这与简单的投影文档不

mongodb - 为集合中的过期数据设置 TTL

是否有使用officialmongodriver按键配置数据自删除的正确方法??我在Mongo-driver模块中找到的唯一方法是ExpireAfterSeconds,但我不确定如何正确使用它。这是repository与目前准备好的东西。 最佳答案 你需要在n秒后需要删除的字段上创建一个ttl索引。在下面的代码片段中,创建了一个可以设置ttl的expirationTime字段。在记录中设置的expirationTime60秒后,记录将被删除。以下是创建TTL索引的代码:varttl*int32*ttl=60keys:=bsonx.D

mongodb - UUID 作为 _id 错误 - 不能将数组用于 _id

我正在尝试为MongoDB中的_id字段使用UUID。我有一个包装器结构来保存我的记录,如下所示:typemongoWrapperstruct{IDuuid.UUID`bson:"_id"json:"_id"`Paymentstorage.Payment`bson:"payment"json:"payment"`}这是我围绕MongoDB驱动程序包中的InsertOne函数编写的代码:func(s*Storage)Create(newPaymentstorage.Payment)(uuid.UUID,error){mongoInsert:=wrap(newPayment)c:=s.cl

mongodb - 如何根据带有整数键的嵌套数组中的值查找文档?

我的查找查询如下所示:bson.M{"_id":oId,"items":bson.M{"$elemMatch":bson.M{"id":theId,"active":true}}}(其中theId是方法中的对象ID)我要做的是选择一个具有匹配id且active设置为true的文档{"_id":ObjectId("5ca0e44acb216df65405dc5f"),"items":{"0":{"id":ObjectId("5c9fbb25e86deef65491c321"),"active":true},"1":{"id":ObjectId("5c9fbb57cb216df65405d

mongodb - 为什么我的 mongodb 查询返回 0 个结果?

这是我的数据库集合:使用此go代码,我尝试获取所有参与故事或使用给定ID创建故事的用户。funcmain(){forstf.DB==nil{}collection:=stf.DB.Collection("user")ctx,cancel:=context.WithTimeout(context.Background(),30*time.Second)defercancel()id,_:=primitive.ObjectIDFromHex("5cb4dd7e29d3dca573a73d4c")fter:=bson.M{"_id":id}involvedFilter:=bson.M{"st

mongodb - 如何从 wasm 模块连接到本地 mongodb 实例?

我正在尝试使用编译为WebAssembly的Go将一些数据存储在我的本地MongoDB实例中。问题是,我什至无法连接到它。mondog实例不会以任何方式对来自wasm模块的连接使用react。只有从wasm模块连接时才会出现此问题。以普通方式编译时相同的代码工作正常,以及来自mongoshell的连接。运行的mongod实例没有密码保护。如果重要的话,我的操作系统是Windows10。我尝试将mongodbind_ip参数从localhost更改为我机器的实际本地地址,并使用不同的浏览器(Chrome75.0.3770.80,Opera60.0.3255.109)。更改超时持续时间也无

mongodb - go.mongodb.org/mongo-driver - InsertOne with NilValueObjectId

我有以下结构typeAccountstruct{IDprimitive.ObjectID`json:"id"bson:"_id"`Emailstring`json:"email"`Passwordstring`json:"password"`}和下面的函数func(a*Account)Create()map[string]interface{}{ifresp,ok:=a.Validate();!ok{returnresp}hashedPassword,_:=bcrypt.GenerateFromPassword([]byte(a.Password),bcrypt.DefaultCost

mongodb - 如何正确写嵌套的bson.M{}

假设我们有以下结构:typeshopstruct{IDprimitive.ObjectID`json:"_id,omitempty"bson:"_id,omitempty"`Brands*brand`json:"brand,omitempty"bson:"brand,omitempty"`}typebrandstruct{IDprimitive.ObjectID`json:"_id,omitempty"bson:"deploymentid,omitempty"`}我尝试使用findOne()查找文档,但即使使用MongoDBshell有匹配结果,我也没有得到任何文档。filter:=b

mongodb - 如何在 Go 中保持客户端与 MongoDB 的连接?

go-mongo-driver文档位于https://www.mongodb.com/blog/post/mongodb-go-driver-tutorial建议如下:ItisbestpracticetokeepaclientthatisconnectedtoMongoDBaroundsothattheapplicationcanmakeuseofconnectionpooling-youdon'twanttoopenandcloseaconnectionforeachquery.我的问题是:是否有关于如何执行此操作的最佳实践?我正在运行一个RPC服务并持续监听请求。当我收到请求时,我