当前位置: > > > > golang中的聚合查询
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的相关知识,也可关注米云公众号。
