首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在mongo中查找树形层次结构

在mongo中查找树形层次结构
EN

Stack Overflow用户
提问于 2020-07-11 02:02:29
回答 1查看 46关注 0票数 0

我有表示树层次结构元数据的集合,站点和地理位置集合,一个元可以有多个站点,一个站点可以有多个地理位置

元集合

代码语言:javascript
复制
{
    "_id": "1",
    "meta_id": 1,
    "meta_name": "yankung"
}

网站集

代码语言:javascript
复制
{
    "_id": "1",
    "meta_id": 1,
    "site_id" :2,
    "site_name": "uoop"
}

地理集合

代码语言:javascript
复制
{
    "_id": "1",
    "site_id": 2,
    "geo_id" :3,
    "geo_name": "toop"
}

我必须像这样得到最终的结果

代码语言:javascript
复制
{
  "_id": "1",
  "meta_id": 1,
  "meta_name": "yankung",
  "sites": [
    {
      "site_id": 2,
      "site_name": "uoop",
      "geos:": [
        {
          "geo_id": 3,
          "geo_name": "toop"
        },
        {
          "geo_id": 4,
          "geo_name": "toop"
        }
      ]
    },
    {
      "site_id": 1000,
      "site_name": "uoop",
      "geos:": [
        {
          "geo_id": 5,
          "geo_name": "toop"
        },
        {
          "geo_id": 6,
          "geo_name": "toop"
        }
      ]
    }
  ]
}

我尝试使用聚合查询和查找,展开能够将站点和地理位置分离为列表,我想从应用程序级别获得所需的结果,但必须迭代每个文档并添加,这将增加时间复杂性,有没有关于如何继续的帮助?

这就是我所能做到的

代码语言:javascript
复制
{
  "_id": "1",
  "meta_id": 1,
  "meta_name": "yankung",
  "sites": [
    { "site_id": 2, "site_name": "uoop"
    },
    {"site_id": 1000,"site_name": "uoop"
    }
      ],
   "geos:": [
        { "geo_id": 5,"geo_name": "toop"
        },
        {"geo_id": 6,"geo_name": "toop"
        }
  ]
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-07-11 18:10:19

诀窍是使用$lookup with join conditions and uncorrelated subqueries。通过这种方式,您可以在$lookup中定义$lookup。

下面是查询:

代码语言:javascript
复制
db.meta_collection.aggregate([
  {
    $lookup: {
      from: "site_collection",
      let: {
        meta: "$meta_id"
      },
      pipeline: [
        {
          $match: {
            $expr: {
              $eq: [
                "$meta_id",
                "$$meta"
              ]
            }
          }
        },
        {
          $lookup: {
            from: "geo_collection",
            let: {
              site: "$site_id"
            },
            pipeline: [
              {
                $match: {
                  $expr: {
                    $eq: [
                      "$site_id",
                      "$$site"
                    ]
                  }
                }
              },
              
            ],
            as: "geos"
          }
        }
      ],
      as: "sites"
    }
  }
])

你可以在here上测试它

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62839927

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档