Bạn có thể thử tổng hợp bên dưới.
Các giai đoạn $match - $graphLookup - $project
.
$reduce
để chọn phần tử đầu tiên từ mỗi $graphLookup
nameList's
na
mảng.
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]
}]
}
}
}
}
}])