json - 如何在 mongodb 中展平子文档

标签 json node.js mongodb export-to-csv

我的收藏中有这样的文档

{
"_id" : ObjectId("587c8d0364b6e32706f7edef"),
"first_name" : "John",
"last_name" : "Doe",
"password" : "aasdjsabb12213b21bbcghc1h2",
"shift" : "A",
"dept" : "Management"
"Requests" : [
    {
        "weekId" : 1,
        "MO" : 1,
        "TU" : 2,
        "W" : 3,
        "TH" : 9,
        "FR" : 10,
        "SA" : 6,
        "SU" : 1
    }
  ]
}

我想将查询结果导出到 csv 并需要像这样展平的字段

{
"_id" : ObjectId("587c8d0364b6e32706f7edef"),
"first_name" : "John",
"last_name" : "Doe",
"password" : "aasdjsabb12213b21bbcghc1h2",
"shift" : "A",
"dept" : "Management"
"weekId" : 1,
"MO" : 1,
"TU" : 2,
"W" : 3,
"TH" : 9,
"FR" : 10,
"SA" : 6,
"SU" : 1

}

我尝试使用聚合函数但无济于事。谁能建议我如何做到这一点?

这是我的工作代码,但我认为这不是正确的方法

db.req.aggregate([{$unwind:'$Requests'},{$project:    {first_name:1,last_name:1,dept:1,"WeekId":"$Requests.weekdId","Mon":"$Requests.MO","Tue":"$Requests.TU","Wed":"$Requests.W","Thu":"$Requests.TH","Fri":"$Requests.FR","Sat":"$Requests.SA","Sun":"$Requests.SU"}},{$out:"results"}]);

最佳答案

您可以使用聚合查询来完成此操作,但它不是很漂亮:

db.test.aggregate([
    {$unwind:"$Requests"},
    {$project:
         {_id:1,
          first_name:1,
          last_name:1,
          password:1,
          shift:1,
          dept:1,
          weekId:"$Requests.weekId",
          MO:"$Requests.MO",
          TU:"$Requests.TU",
          W:"$Requests.W",
          TH:"$Requests.TH",
          FR:"$Requests.FR",
          SA:"$Requests.SA",
          SU:"$Requests.SU"}}])
    .pretty()

所以基本上展开 Requests 数组,然后投影出您想要生成的文档。希望这是有道理的。

关于json - 如何在 mongodb 中展平子文档,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41684831/

相关文章:

javascript - 显示 Json 数据 jQuery PHP MySQL

node.js - 编写回调的异步/等待版本

node.js - 如何使用 Heroku 作为 API 代理(Node.js)?

mongodb - mgo $unwind 聚合结果到未知元素种类 (0x2E)

html - 以 Angular 5 在 HTML 上显示来自 json 对象的数据

javascript - 写入 JSON 文件(使用 Node.js 在本地主机服务器上工作)

javascript - Localhost 拒绝来自 Javascript 的连接

php - Javascript JSON 到 PHP 数组

ajax - 我是否需要使用 Ajax 才能不被视为机器人?

c# - Mongodb 聚合组然后使用 C# 进行条件求和