Necesitas dos etapas adicionales. En primer lugar, puede ejecutar $reduce
para aplanar ExerciseDetail
que ahora es una matriz de matrices. Una vez hecho esto, puede ejecutar $map
con anidado $filter
para emparejar Sets
con ExerciseDetails
:
{
$addFields: {
ExerciseDetail: {
$reduce: {
input: "$ExerciseDetail",
initialValue: [],
in: {
$concatArrays: [ "$$value", "$$this" ]
}
}
}
}
},
{
$project: {
_id: 1,
Sets: {
$map: {
input: "$Sets",
as: "set",
in: {
$let: {
vars: {
exDetail: {
$arrayElemAt: [
{ $filter: { input: "$ExerciseDetail", cond: { $eq: [ "$$this._id", "$$set.ExerciseId" ] } } },
0
]
}
},
in: {
$mergeObjects: [
"$$set", "$$exDetail"
]
}
}
}
}
}
}
}