我正在使用 Typescript 中的 Nodejs 驅動程式學習 MongoDB;我想從具有“動態”投影的檔案中檢索子檔案;這應該使用列出所需欄位的陣列來完成:
{
"_id" : ObjectId("6006be017fdd3b1018e0f533"),
"name" : "Cindy",
"surname" : "Red",
"age" : 30.0,
"various" : {
"aaa1" : "111",
"bbb2" : "222"
}
}
{
"_id" : ObjectId("6006be0b7fdd3b1018e0f534"),
"name" : "Valentina",
"surname" : "Green",
"age" : 30.0,
"various" : {
"ccc3" : "333",
"ddd4" : "444"
}
}
// This piece of code to execute the query:
const arrayValues = ["$various"];
const result = await myConnectedClient
.db("ZZZ_TEST_ALL")
.collection("my_collection_01")
.aggregate<any>([
{ $project: { _id: 0, arrayValues } },
]);
結果:
{
_id: 6006be017fdd3b1018e0f533,
arrayValues: [ { aaa1: '111', bbb2: '222' } ]
}
{
_id: 6006be0b7fdd3b1018e0f534,
arrayValues: [ { ccc3: '333', ddd4: '444' } ]
}
但我想要這樣的結果:
{
various: { aaa1: '111', bbb2: '222' }
}
{
various: { ccc3: '333', ddd4: '444' }
}
謝謝。
uj5u.com熱心網友回復:
這應該做
const arrayValues = ["$various"];
const result = await myConnectedClient
.db("ZZZ_TEST_ALL")
.collection("my_collection_01")
.aggregate<any>([{ $project: { _id: 0, arrayValues } }])
.map((e) =>
Object.keys(e.arrayValues[0]).map((k) => {
return { [k]: e.arrayValues[0][k] };
})
)
.map((v) => {
return { various: Object.assign({}, ...v) };
});
列印(作為 JSON)
[
{ "various": { "aaa1": "111", "bbb2": "222" } },
{ "various": { "ccc3": "333", "ddd4": "444" } }
]
轉載請註明出處,本文鏈接:https://www.uj5u.com/net/382664.html
標籤:javascript 节点.js 打字稿 MongoDB 聚合框架
上一篇:useReducer和userContextTypescript沒有按預期作業
下一篇:如何在打字稿中將空檢查拉入函式
