登录
首页 >  Golang >  Go问答

golang中的聚合查询

来源:stackoverflow

时间:2024-04-23 08:42:32 402浏览 收藏

一分耕耘,一分收获!既然都打开这篇《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学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>