草庐IT

数据MongoDB

全部标签

go - 创建具有类型接口(interface)的映射以通过 URL 参数接受任意数据类型

我想将URL参数从字符串转换为正确的数据类型并将其存储在map中。我认为类型应该是[]interface,用于存储多种数据类型的列表。我正在创建一个键值存储,但目前它只存储字符串。我已经阅读了关于将数据转换为字节的GOB,但不明白。我已经尝试过类型断言,但是,我不相信在我的情况下这会起作用,因为数据来自默认情况下已经是字符串的URL。如何检测条目是否为字符串、整数、bool值等?map:vardatamap[string][]string调用handleCreate函数的主函数中的handleFuncr.HandleFunc("/insert/{key}/{value}",handle

mongodb - 使用golang从MongoDB批量获取记录

如何使用golang从mongo数据库中批量获取记录?我知道mongoDB本身有一个叫做cursor.batchSize()的东西,但我试图找到一个使用golang驱动程序的例子。据我所知,golang库mgo有一个名为Batch的函数,但我想弄清楚如何使用它。理想情况下,我正在寻找这样的东西:constcursor=useDb.collection(mycollection).find().batchSize(10000);for(letdoc=awaitcursor.next();doc!=null;doc=awaitcursor.next()){if(doc._id%diviso

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

json - 打印 POST JSON 数据

我在从POST打印JSON时遇到问题。我使用gorilla/mux进行路由r:=mux.NewRouter()r.HandleFunc("/test",Point).Methods("POST")http.ListenAndServe(":80",r)`在Point函数中我有funcPoint(whttp.ResponseWriter,r*http.Request){varcallbackDecoderjson.NewDecoder(r.Body).Decode(&callback)}但只有当我知道结构并且我想弄清楚如何将整个JSON作为字符串log.Print时,我才能使用此方法。我

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

oracle - 从 Go 应用程序到 Oracle 数据库的 SQL 查询引发错误?

我接下来使用article将Golang应用程序与远程Oracle数据库连接起来。应用程序在库的帮助下成功连接到数据库goracle.我也ping通了。当我进行sql查询时,应用程序引发错误。哪里错了?我注意到,如果从Controller文件(organizations.go)中删除所有代码到连接文件(Oracle.go),它会起作用。我究竟需要如何重构?错误:2019/03/1318:15:47http:panicserving[::1]:28363:runtimeerror:invalidmemoryaddressornilpointerdereferencegoroutine54

go - 如何获取时区数据库名称

关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭3年前。Improvethisquestion我试图在Debian上运行Go获取tz数据库名称,例如“US/Arizona”,但没有找到方法。我可以获得时区缩写,但这不是我想要的。我在网上搜索了一下,没有找到任何线索。伙计们,有什么想法吗?

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