MongoDB根据条件按计数分组



我有以下mongo数据库模式:

{
"_id" : "5b76c3c037548390fdb5b40e",
"userId" : "4601",
"modified" : ISODate("2018-08-21T19:13:43.301+05:30"),
"rStatus" : "started",
},
{
"_id" : "5b76c3c037548390fdb5b40e",
"userId" : "13",
"modified" : ISODate("2018-08-21T19:13:43.301+05:30"),
"rStatus" : "completed",
},
........

需要按修改日期和rStatus字段的计数获取数据组,例如

{
modified:"2018-08-21",
count :{"completed":1,"ongoing":4}
},
{
modified:"2018-07-23",
count :{"completed":2,"ongoing":5}
},

我正在使用$group但它仅按修改日期计数,而不是按内部键的值计数。

您可以在 3.6 中使用以下聚合。

db.colname.aggregate([
{"$group":{
"_id":{
"date":{"$dateToString":{"date":"$modified","format":"%Y-%m-%d"}},
"rstatus":"$rStatus"
},
"count":{"$sum":1}
}},
{"$group":{
"_id":"$_id.date",
"count":{"$mergeObjects":{"$arrayToObject":[[["$_id.rstatus","$count"]]]}}
}}])

相关内容

  • 没有找到相关文章

最新更新