Kei*_*rsh 3 mongodb aggregation-framework
我有一个具有以下结构的文档,在获取前10个软件包的过程中,我希望获得过去2个月的总计2013.5和2013.4。
如果我使用聚合
db.hits.aggregate(
{$project:{"total":{"$add":["$value.2013.5", "$value.2013.4"]}}})
Run Code Online (Sandbox Code Playgroud)
仅当两个字段都存在于文档中时,这才返回总计的数值。如果缺少任何字段,则total的值为null。关于如何解决这个问题的任何想法。$ project之后有$ group,$ sort,$ limit,但是为了清楚起见,我省略了它们。
{
"_id" : "4e6eef33-d88a-4d4d-a6b2-6becf1be7e8f",
"value" : {
"package" : 4498
"2012" : {
"1" : 1.0,
"2" : 1.0,
"4" : 1.0,
"6" : 4.0,
"7" : 2.0,
"8" : 5.0,
"12" : 1.0,
"hits" : 15.0
},
"2013" : {
"1" : 6.0,
"4" : 2.0,
"hits" : 8.0
},
"hits" : 23.0
}
}
Run Code Online (Sandbox Code Playgroud)
顺便说一下,我仅用两个月来进行说明。我通常会使用12个月。
编辑:我的后备是写一个函数来添加文档中缺少的字段。我很想知道是否有办法避免这样做。
仅当两个字段都存在于文档中时,这才返回总计的数值。
如果其中一个字段不存在,则将其视为undefined。undefined值将在任何操作中传播。
如果我使用汇总[...]
您可以使用$ ifNull运算符:
db.hits.aggregate({$project:{"total":{"$add":[{$ifNull: ["$value.2013.5", 0]}, {$ifNull: ["$value.2013.4", 0]}]}}})
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
877 次 |
| 最近记录: |