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"
}
}
])
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"
}
}
])
我有这样的文档:
[
{ 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"
}
}
])
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"
}
}
])