当前位置: > > > > golang中的聚合查询
来源:stackoverflow
2024-04-23 08:42:32
0浏览
收藏
一分耕耘,一分收获!既然都打开这篇《golang中的聚合查询》,就坚持看下去,学下去吧!本文主要会给大家讲到等等知识点,如果大家对本文有好的建议或者看到有不足之处,非常欢迎大家积极提出!在后续文章我会继续更新Golang相关的内容,希望对大家都有所帮助!
问题内容
我需要用 mgo 在 golang 中编写一个查询,这是 mongo 中的查询:
db.some.aggregate([ {$match: { "data.id": "11111" }}, {$project: { _id : 0, url : { $concat: [ "https://www.someurl.com/","$data.aID" ]}, items :{ "$map":{ "input":"$data.items", "as":"it", "in":{ "item_title":"$$it.title", "item_id":"$$it.id" }}}}])
如果您能帮助解决这个问题,我将不胜感激。
// 对于错误提出的问题,我深表歉意,以后我会按照说明进行操作,我的问题是 $concat
解决方案
这里的语法很棘手,因为它与 json 类似,但又不同,足以令人困惑。
特别请注意,数组使用大括号分隔符 []bson.m{...}
并且 $concat
值是字符串数组 []string{...}
:
query := []bson.M{ // NOTE: slice of bson.M here bson.M{ "$match": bson.M{"data.id": "11111"}, }, bson.M{ "$project": bson.M{ "_id": 0, "url": bson.M{ "$concat": []string{ // NOTE: slice of strings here "https://www.someurl.com/", "$data.aID", }, }, "items": bson.M{ "$map": bson.M{ "input": "$data.items", "as": "it", "in": bson.M{"item_title": "$$it.title", "item_id": "$$it.id"}, }, }, }, }, }
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持!更多关于Golang的相关知识,也可关注公众号。