簡體   English   中英

Mongodb 中的聚合與動態投影

[英]Aggregation in Mongodb with dynamic projection

我正在使用 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' } 
}

謝謝。

這應該這樣做

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" } }
]

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM