繁体   English   中英

MongoDB 在嵌套数组聚合中查找

[英]MongoDB find in nested array aggregation

我有嵌套数组文档解释如下:

countries: [
  {
    "id": "id of country",
    "cities": [
      {
        "id": "id of city 1",
        "areas": [
          {
            "id": "id of area 1"
          },
          {
            "id": "id of area 2"
          },
          {
            "id": "id of area 3"
          },
          {
            "id": "id of area 4"
          }
        ]
      },
      {
        "id": "id of city 2",
        "areas": [
          {
            "id": "id of area 1"
          },
          {
            "id": "id of area 2"
          },
          {
            "id": "id of area 3"
          },
          {
            "id": "id of area 4"
          }
        ]
      }
    ]
  }
]

我的目标是使用$addFields添加一个字段来指示给定的 id 是否与区域 ID 匹配。

{$addFields: {
    isDeliveringToArea: {
      $in: [ObjectId('5db5d11cb18a2500129732a5'),'$countries.cities.areas.id']
    } 
}}

但显然$in不适用于嵌套数组。 我想要类似 find 方法的东西Model.find({'countries.cities.areas.id': 'areaID'})但在聚合中返回一个布尔值。

由于有 3 级嵌套数组,我们可以使用$map来实现这一点,它用于运行所有/修改对象。 首先$map使用要经过每一个国家对象,第二个$map经常去各个国家对象内各城市的对象

更新 1

因为你需要所有的文件,你可以用$anyElementTrue ,这有助于如果我们的条件下有任何元素为真,它会发出true

为整个国家工作的Mongo 游乐场

[
  {
    "$addFields": {
      isDeliveringToArea: {
        $anyElementTrue: {
          $map: {
            input: "$countries",
            in: {
              $anyElementTrue: {
                $map: {
                  input: "$$this.cities",
                  in: {
                    $in: [
                      "6",
                      "$$this.areas.id"
                    ]
                  }
                }
              }
            }
          }
        }
      }
    }
  }
]

我保留旧查询供您参考。 每个国家对象的工作Mongo 游乐场

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM