我有一个MongoDB查询,它使用如下所示的聚合框架:
System._get_collection().aggregate([
{ "$match": {
"system_id": system.id,
"utc_timestamp": {
"$gte": datetime.datetime.now().replace(hour=0, minute=0, second=0, microsecond=0) - datetime.timedelta(days=1),
"$lt": datetime.datetime.now().replace(hour=0, minute=0, second=0, microsecond=0)
}
}},
{ "$group": {
"_id": { "$dayOfYear": "$utc_timestamp" },
"correct": {
"$sum": { "$cond": [
{ "$eq": [ "$status", 455 ]}, 1, 0
]}
},
"total_count": { "$sum": 1 }
}},
{ "$project": {
"correctness": {
"$cond": [
{ "$eq": [ "$correct", 0 ] },
0,
{ "$multiply" : [{"$divide": [ "$correct", "$total_count" ]}, 100] }
]
}
}}
])输出如下所示:
{'result': [{'_id': 272, 'correctness': 99.89373007438896}], 'ok': 1.0}我想在结果中添加一个字段,这是每个匹配的delay文档中所有System字段的平均值。
我试图将"delay": { "$avg": "$delay" },添加到$group部分,但没有更改结果。
我想要这样的结果:
{'result': [{'_id': 272, 'correctness': 99.89373007438896, 'delay': 5}], 'ok': 1.0}注意上面的'delay': 5,它应该是计算的平均值。
我需要把这个加到投影中吗?或者,我是不是做错了什么?
发布于 2014-09-30 02:04:59
除了_id之外,您从$project中省略的任何字段都不包含在输出中,因此只需将delay添加到其中:
{ "$project": {
"correctness": {
"$cond": [
{ "$eq": [ "$correct", 0 ] },
0,
{ "$multiply" : [{"$divide": [ "$correct", "$total_count" ]}, 100] }
]
},
"delay": 1
}}https://stackoverflow.com/questions/26111436
复制相似问题