user3012872
user3012872

Reputation: 25

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

I have documents like this:

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

How to get documents with combination of other values like example below using aggregation framework?

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

Upvotes: 1

Views: 37

Answers (1)

YuTing
YuTing

Reputation: 6629

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

Upvotes: 1

Related Questions