आप नीचे एकत्रीकरण की कोशिश कर सकते हैं।
चरण $match - $graphLookup - $project
।
$reduce
प्रत्येक $graphLookup
. से पहला तत्व चुनने के लिए nameList's
na
सरणी।
db.taxon.aggregate([{
$match: {
_id: {
$in: listId
}
}
}, {
$graphLookup: {
from: "taxon",
startWith: "$_id",
connectFromField: "pa",
connectToField: "_id",
as: "nameList"
}
}, {
$project: {
nameList: {
$reduce: {
input: "$nameList",
initialValue: [],
in: {
"$concatArrays": ["$$value", {
$slice: ["$$this.na", 1]
}]
}
}
}
}
}])