MongoDB。如何在聚合框架中将文档与其他文档值结合起来?

MongoDB. How to combine document with other documents values in aggregation framework?

我有这样的文档:

[
  { id: 1, number: 10 },
  { id: 2, number: 11 },
  { id: 3, number: 12 }
]

如何使用聚合框架获取包含其他值组合的文档,如下例所示?

[
  { id: 1, number: 10, other_numbers: [11, 12] },
  { id: 2, number: 11, other_numbers: [10, 12] },
  { id: 3, number: 12, other_numbers: [10, 11] }
]
db.collection.aggregate([
  {
    $lookup: {
      "from": "collection",
      "let": {
        "number": "$number"
      },
      pipeline: [
        {
          $match: {
            $expr: {
              $ne: [ "$number", "$$number" ]
            }
          }
        }
      ],
      "as": "other_numbers"
    }
  },
  {
    $set: {
      "other_numbers": "$other_numbers.number"
    }
  }
])

mongoplayground


db.collection.aggregate([
  {
    "$group": {
      "_id": null,
      "number": {
        "$push": "$$ROOT"
      },
      "other_numbers": {
        "$push": "$$ROOT"
      }
    }
  },
  {
    "$unwind": "$number"
  },
  {
    "$set": {
      "other_numbers": {
        "$filter": {
          "input": "$other_numbers.number",
          "as": "i",
          "cond": {
            "$ne": [
              "$$i",
              "$number.number"
            ]
          }
        }
      },
      "number": "$number.number",
      "_id": "$number.id"
    }
  }
])

mongoplayground