聚合:将嵌套文档中(嵌套对象)的日期分组并显示计数?


对于聚合,在 MongoDB 中使用 aggregate()。使用 $group 将日期分组。让我们创建一个包含文档的集合 −

> db.demo717.insertOne(
...    {
...       "shippingdetails":
...       [
...          {
...             duedate:"2020-04-29 22:33:04",
...          },
...          {
...             duedate:"2020-03-29 22:33:04",
...          },
...          {
...             duedate:"2020-04-29 22:33:04",
...          },
...          {
...             duedate:"2020-01-29 22:33:04",
...          }
...       ]
...    }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5ea9b3cd85324c2c98cc4c30")
}

使用 find() 方法显示集合中的所有文档 −

> db.demo717.find().pretty();

这会产生以下输出 −

{
   "_id" : ObjectId("5ea9b3cd85324c2c98cc4c30"),
   "shippingdetails" : [
      {
         "duedate" : "2020-04-29 22:33:04"
      },
      {
         "duedate" : "2020-03-29 22:33:04"
      },
      {
         "duedate" : "2020-04-29 22:33:04"
      },
      {
         "duedate" : "2020-01-29 22:33:04"
      }
   ]
}

以下是将嵌套文档(嵌套对象)中日期分组的聚合查询 −

> db.demo717.aggregate(
...    {
...       $unwind:"$shippingdetails"},
...       {
...          $group: {
...             _id: "$shippingdetails.duedate",
...          count: {
...             $sum: 1
...          }
...       }
...    }
... )

这会产生以下输出 −

{ "_id" : "2020-01-29 22:33:04", "count" : 1 }
{ "_id" : "2020-03-29 22:33:04", "count" : 1 }
{ "_id" : "2020-04-29 22:33:04", "count" : 2 }

更新日期:2020 年 5 月 14 日

226 次浏览

开启你的 职业生涯

完成课程,获得认证

开始学习
广告
© . All rights reserved.