【发布时间】:2017-07-17 20:17:24
【问题描述】:
我已经在我的收藏中分配了人员、状态,如下所示。
[
{"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 对这些数据进行分组,并在其中按每个 STATUS 的 STATUS 计数和最近更新的 SPEC_ID强> 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
}
],
}
]
【问题讨论】:
-
您的文档没有
INSPECTED_BY字段,这是故意遗漏吗? -
你可以在命令中使用$first,db.testCollection.aggregate([{ $group: { _id: { ASSIGN_ID: "$ASSIGN_ID", STATUS: "$STATUS" }, count: { " $sum": 1 } ,"SPEC_ID":{$first:"$SPEC_ID"}} }, { $group: { _id: "$_id.ASSIGN_ID", STATUS_GROUP: { $push: { STATUS: "$_id. STATUS", count: "$count" } } ,"SPEC_ID":{$first:"$SPEC_ID"} }}])
-
radhakrishnan,它返回一个错误调用 MongoError: invalid operator '$first'
标签: javascript mongodb mongoose mongodb-query aggregation-framework