如何找到嵌套数组数据?

时间:2019-02-02 08:57:32

标签: javascript mongodb mongoose

我有一个模特:

const schema = new mongoose.Schema({
  country: { type: String },
  code: { type: String },
  region: [{
    name: { type: String },
    city: [{
      name: { type: String },
      latitude: { type: String },
      longitude: { type: String },
    }],
  }],
})

我需要获取地区列表->城市->名称(城市名称列表) 首先,我尝试查询以获取(Array)city的列表

const list = await Model.findOne(
  { $and: [{ code: req.params.code }, { 'region.name': 'Harjumaa' }] },
  { 'region.city.name': 1 },
)

和接收这样的数据:

enter image description here

然后我搜索要发送查询的区域列表:

Model.findOne({ code: req.params.code }, { region: 1 })

和接收数据是这样的:

enter image description here

我想以相同的格式获取城市名称列表。

我的数据样本:

{
  "country": "Estonia",
  "code": "ee",
  "region": [
    {
      "name": "Harjumaa",
      "city": [
        {
          "name": "Aegviidu vald",
          "latitude": "59.27941132",
          "longitude": "25.62571907"
        },
        {
          "name": "Anija vald",
          "latitude": "59.27643967",
          "longitude": "25.48167992"
        }
      ]
    }
  ]
}

1 个答案:

答案 0 :(得分:1)

路径为$project

$region.city.name将为您提供一个数组数组,因为您有两个嵌套级别。要解决此问题,可以将Here$reduce结合使用,这会将最终结果展平为单个数组,请尝试:

Model.aggregate([
    {
        $match: { code: "ee" }
    },
    {
        $project: {
            cityNames: {
                $reduce: {
                    input: "$region.city.name",
                    initialValue: [],
                    in: { $concatArrays: [ "$$this", "$$value" ] }
                }
            }
        }
    }
])