我正在尝试按天汇总我的数据,以便将其呈现在图表中。我通过按 、 和 分组成功地做到了$year
这$month
一点$dayOfMonth
。但是,这意味着我的日期现在在最终结果中分为三个部分。有没有办法将这三个数字连接回日期格式,或者有没有另一种方法可以按天分组而不拆分日期?下面是我所拥有的一个工作示例:
Sentiment.aggregate([
{
$match: { 'content.term' : term_id }
}, {
$group: {
_id: {
year : { $year : '$created_at' },
month : { $month : '$created_at' },
dayOfMonth : { $dayOfMonth : '$created_at' },
},
sum : { $sum : '$score'},
count : { $sum : 1 }
},
}, {
$project: {
_id : 0,
date : '$_id',
sum : 1,
count : 1,
avg : { $divide: ['$sum', '$count'] }
}
}
], function(err, result){
if(err) callback(err);
else callback(null, result);
});
这是一个示例结果:
[
{
"sum": 201,
"count": 3,
"date": {
"year": 2013,
"month": 7,
"dayOfMonth": 5
},
"avg": 67
},
{
"sum": 186,
"count": 6,
"date": {
"year": 2013,
"month": 7,
"dayOfMonth": 8
},
"avg": 31
},
{
"sum": 834,
"count": 9,
"date": {
"year": 2013,
"month": 7,
"dayOfMonth": 9
},
"avg": 92.66666666666667
}
]
理想情况下,我希望有date
一个有效的日期,所以我以后不必转换它。我试过使用$concat
,但这只适用于字符串。如果有什么不同,我正在使用Mongoose
。