आप $reduce का इस्तेमाल कर सकते हैं $concatArrays के साथ अपनी डेटा संरचना को समतल करने के लिए और फिर $unwind $replaceRoot के साथ प्रति दस्तावेज़ एकल सदस्य प्राप्त करने के लिए:
db.collection.aggregate([
{ "$project": {
"members": {
"$concatArrays": [
[{ "userID": "$userID", "userType": "$userType" }],
{ "$reduce": {
"input": "$clients",
"initialValue": [],
"in": {
"$concatArrays": [
"$$value",
[{ "userID": "$$this.userID", "userType": "$$this.userType" }],
"$$this.members"
]
}
}}
]
}
}},
{ "$unwind": "$members" },
{ "$replaceRoot": { "newRoot": "$members" }}
])