我试图在 MongoDB 聚合管道的 $group 阶段有条件地将字段推入数组。
本质上,我有包含用户名的文档以及他们执行的一系列操作。
如果我将用户操作分组如下:
{ $group: { _id: { "name": "$user.name" }, "actions": { $push: $action"} } }
我得到以下信息:
[{
"_id": {
"name": "Bob"
},
"actions": ["add", "wait", "subtract"]
}, {
"_id": {
"name": "Susan"
},
"actions": ["add"]
}, {
"_id": {
"name": "Susan"
},
"actions": ["add, subtract"]
}]
到目前为止,一切都很好。现在的想法是将动作数组组合在一起,看看哪些用户操作集是最受欢迎的。问题是我需要在考虑该组之前删除“等待”操作。因此,考虑到分组中不应考虑“wait”元素,结果应该是这样的:
[{
"_id": ["add"],
"total": 1
}, {
"_id": ["add", "subtract"],
"total": 2
}]
Test #1
如果我添加这个 $group 阶段:
{ $group : { _id : "$actions", total: { $sum: 1} }}
我得到了我想要的计数,但它考虑了不需要的“等待”数组元素。
[{
"_id": ["add"],
"total": 1
}, {
"_id": ["add", "subtract"],
"total": 1
}, {
"_id": ["add", "wait", "subtract"],
"total": 1
}]
Test #2
{ $group: { _id: { "name": "$user.name" }, "actions": { $push: { $cond: { if:
{ $ne: [ "$action", 'wait']}, then: "$action", else: null } }}} }
{ $group : { _id : "$actions", total: { $sum: 1} }}
这是我所得到的最接近的结果,但这会将空值推入等待的位置,并且我不知道如何删除它们。
[{
"_id": ["add"],
"total": 1
}, {
"_id": ["add", "subtract"],
"total": 1
}, {
"_id": ["add", null, "subtract"],
"total": 1
}]
UPDATE:
我的简化文档如下所示:
{
"_id": ObjectID("573e0c6155e2a8f9362fb8ff"),
"user": {
"name": "Bob",
},
"action": "add",
}