Du behöver ytterligare två steg. För det första kan du köra $reduce
för att platta ut ExerciseDetail
som nu är en array av arrayer. När det är klart kan du köra $map
med kapslade $filter
för att para ihop Sets
med 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"
]
}
}
}
}
}
}
}