我已在我的收藏中分配了人员,状态,如下所示。
[
{"ASSIGN_ID": "583f84bce58725f76b322398", "SPEC_ID" : "58411771", "STATUS": 1, "UPDATE_DATE": ISODate("2016-12-21T04:10:23.000Z")},
{"ASSIGN_ID": "583f84bce58725f76b322398", "SPEC_ID" : "58411772", "STATUS": 4, "UPDATE_DATE": ISODate("2016-12-22T04:10:23.000Z")},
{"ASSIGN_ID": "583f84bce58725f76b322398", "SPEC_ID" : "58411774", "STATUS": 4, "UPDATE_DATE": ISODate("2016-12-23T04:10:23.000Z")},
{"ASSIGN_ID": "583f84bce58725f76b322398", "SPEC_ID" : "58411774", "STATUS": 3, "UPDATE_DATE": ISODate("2016-12-24T04:10:23.000Z")},
{"ASSIGN_ID": "583f84bce58725f76b322311", "SPEC_ID" : "58411775", "STATUS": 1, "UPDATE_DATE": ISODate("2016-12-25T04:10:23.000Z")},
{"ASSIGN_ID": "583f84bce58725f76b322311", "SPEC_ID" : "58411779", "STATUS": 3, "UPDATE_DATE": ISODate("2016-12-23T04:10:23.000Z")},
{"ASSIGN_ID": "583f84bce58725f76b322322", "SPEC_ID" : "58411777", "STATUS": 1, "UPDATE_DATE": ISODate("2016-12-20T04:10:23.000Z")},
{"ASSIGN_ID": "583f84bce58725f76b322322", "SPEC_ID" : "58411778", "STATUS": 4, "UPDATE_DATE": ISODate("2016-12-21T04:10:23.000Z")}
]
我希望按 ASSIGN_ID 对此数据进行分组,并在状态计数状态和最近更新的 SPEC_ID < strong>按 UPDATE_DATE 。同如下。 (预期结果)
[
{
"ASSIGN_ID":"583f84bce58725f76b322398",
"STATUS_GROUP":[
{
"STATUS":1,
"COUNT":1
},
{
"STATUS":3,
"COUNT":1
},
{
"STATUS":4,
"COUNT":2
}
],
"SPEC_ID": "58411774"
},
{
"ASSIGN_ID":"583f84bce58725f76b322311",
"STATUS_GROUP":[
{
"STATUS":1,
"COUNT":1
},
{
"STATUS":3,
"COUNT":1
}
],
"SPEC_ID": "58411775"
},
{
"ASSIGN_ID":"583f84bce58725f76b322322",
"STATUS_GROUP":[
{
"STATUS":1,
"COUNT":1
},
{
"STATUS":4,
"COUNT":1
}
],
"SPEC_ID": "58411778"
}
]
但是,我能够通过 STATUS 和 ASSIGN_ID 编写嵌套组。无法获取最近的 SPEC_ID 。请在下面找到查询。
Modal.aggregate([
{"$group": {
"_id": {
"INSPECTED_BY": "$INSPECTED_BY",
"STATUS": "$STATUS"
},
"total": { "$sum": 1 }
}},
{"$group": {
"_id": "$_id.INSPECTED_BY",
"data": { "$push": {
"STATUS": "$_id.STATUS",
"total": "$total"
}}
}}]);
并返回如下数据集。
[
{
"ASSIGN_ID":"583f84bce58725f76b322398",
"STATUS_GROUP":[
{
"STATUS":1,
"COUNT":1
},
{
"STATUS":3,
"COUNT":1
},
{
"STATUS":4,
"COUNT":2
}
],
},
{
"ASSIGN_ID":"583f84bce58725f76b322311",
"STATUS_GROUP":[
{
"STATUS":1,
"COUNT":1
},
{
"STATUS":3,
"COUNT":1
}
],
},
{
"ASSIGN_ID":"583f84bce58725f76b322322",
"STATUS_GROUP":[
{
"STATUS":1,
"COUNT":1
},
{
"STATUS":4,
"COUNT":1
}
],
}
]
答案 0 :(得分:1)
首先需要 $sort
进入管道的文档然后在 $group
阶段返回最新的SPEC_ID
字段对于具有 $first
累加器的每个组。
运行以下管道应该会得到您想要的结果:
Model.aggregate([
{ "$sort": { "ASSIGN_ID": 1, "STATUS": 1, "UPDATE_DATE": -1 } },
{
"$group": {
"_id": {
"ASSIGN_ID": "$ASSIGN_ID",
"STATUS" : "$STATUS",
},
"SPEC_ID": { "$first": "$SPEC_ID" },
"COUNT": { "$sum": 1 }
}
},
{
"$group": {
"_id": "$_id.ASSIGN_ID",
"STATUS_GROUP": {
"$push": {
"STATUS": "$_id.STATUS",
"COUNT": "$COUNT"
}
},
"SPEC_ID": { "$first": "$SPEC_ID" }
}
}
]).exec(callback);