猫鼬与嵌套集合聚合

时间:2019-10-21 13:22:56

标签: mongodb mongoose nested aggregate

我有以下架构。

首先:AdditionalFieldSchema

const AdditionalFieldSchema = new Schema({
  names: [
    {
      type: Schema.Types.ObjectId,
      ref: "multiLanguageContent",
      required: true
    }
  ],
  ...
});

第二:MultiLanguageContentSchema

const MultiLanguageContentSchema = new Schema({
  value: {
    type: String,
    required: true
  },
  ...
});

,我有以下猫鼬聚合查询。 目标是获取每个带有附加的additionalField的员工。

    const employees = await Employee.aggregate([
      {
        $match: {
          status: "active",
          $nor: [
            { email: "blablabla" },
            { email: "blobloblo" }
          ]
        }
      },
      {
        $lookup: {
          from: AdditionalField.collection.name,
          let: { af_id: "$_id" },
          pipeline: [{
            $match: {
              $expr: {
                $and: [
                  { $eq: ["$ownership", "$$af_id"] },
                  { $eq: ["$status", "active"] },
                  { $eq: ["$functionalType", "blablabla"] }
                ]
              }
            }
          }],
          as: "afs"
        }
      },
      { $unwind: "$afs" },
      { $unwind: "$afs.names" },
      {
        $group: {
          _id: "$_id",
          email: { $first: "$email" },
          afs: {
            $push: {
              value: "$afs.value",
              names: "$afs.names"
            }
          }
        }
      }
    ]);

我运行的用于测试此聚合函数的查询。

query TestQuery {
  testQuery
  {
    email
    afs {
      names {
        value
      }
      value
    }
  }
}

我得到的结果。

"data": {
    "testQuery": [
      {
        "email": "blablabla@test.com"
        "afs": [
          {
            "names": [
              {
                "value": "Name 1"
              }
            ],
            "value": "Value 1"
          },
          {
            "names": [
              {
                "value": "Name 2"
              }
            ],
            "value": "Value 2"
          },
          ...
        ]
      },
      ...

结果很好,我有想要的数据。 但我想在下面得到这样的结果

"data": {
    "testQuery": [
      {
        "email": "blablabla@test.com",
        "afs": [
          {
            "names": "Name 1",
            "value": "Value 1"
          },
          {
            "names": "Name 2",
            "value": "Value 2"
          },
          ...
        ]
      },
      ...

似乎{ $unwind: "$afs.names" },无效。 有任何想法吗 ? 谢谢,Flo

0 个答案:

没有答案