mae*_*sto 10 mongodb nosql mongodb-query aggregation-framework
我正在尝试对一组文档进行分组,并根据它们的值来计算它们.例如
{ "_id" : 1, "item" : "abc1", "value" : "1" }
{ "_id" : 2, "item" : "abc1", "value" : "1" }
{ "_id" : 3, "item" : "abc1", "value" : "11" }
{ "_id" : 4, "item" : "abc1", "value" : "12" }
{ "_id" : 5, "item" : "xyz1", "value" : "2" }
Run Code Online (Sandbox Code Playgroud)
在这里,我想按"项目"进行分组,并获得一个计数"数值"大于10的次数和小的次数.所以:
{ "item": "abc1", "countSmaller": 2, "countBigger": 1}
{ "item": "xyz1", "countSmaller": 1, "countBigger": 0}
Run Code Online (Sandbox Code Playgroud)
使用$ aggregate可以很容易地实现普通计数,但是如何实现上述结果呢?
Ana*_*lan 13
您需要的是$cond聚合框架的运营商.获得你想要的东西的一种方法是:
db.foo.aggregate([
{
$project: {
item: 1,
lessThan10: { // Set to 1 if value < 10
$cond: [ { $lt: ["$value", 10 ] }, 1, 0]
},
moreThan10: { // Set to 1 if value > 10
$cond: [ { $gt: [ "$value", 10 ] }, 1, 0]
}
}
},
{
$group: {
_id: "$item",
countSmaller: { $sum: "$lessThan10" },
countBigger: { $sum: "$moreThan10" }
}
}
])
Run Code Online (Sandbox Code Playgroud)
注意:我假设value是数字而不是字符串.
输出:
{
"result" : [
{
"_id" : "xyz1",
"countSmaller" : 1,
"countBigger" : 0
},
{
"_id" : "abc1",
"countSmaller" : 2,
"countBigger" : 2
}
],
"ok" : 1
}
Run Code Online (Sandbox Code Playgroud)