为此,您只需要知道问题的数量以及不同配置文件的数量(我认为唯一标识为“pid”)。使用聚合框架,您需要分两个阶段执行此操作:
- 首先,您计算每个 PID 的问题数
- 然后计算每个 PID 的平均问题
你会这样做:
第一步:
db.profiler.aggregate( [
{ $group: { _id: '$pid', count: { '$sum': 1 } } },
] );
哪些输出(在我的情况下,带有一些示例数据):
{
"result" : [
{ "_id" : 2, "count" : 7 },
{ "_id" : 1, "count" : 1 },
{ "_id" : 3, "count" : 3 },
{ "_id" : 4, "count" : 5 }
],
"ok" : 1
}
我有四个配置文件,分别有 7、1、3 或 5 个问题。
现在有了这个结果,我们运行另一个组,但在这种情况下,我们真的不想按任何东西进行分组,因此我们需要将_id
值设置为null,如下面的第二组所示:
db.profiler.aggregate( [
{ $group: { _id: '$pid', count: { '$sum': 1 } } },
{ $group: { _id: null, avg: { $avg: '$count' } } }
] );
然后输出:
{
"result" : [
{ "_id" : null, "avg" : 4 }
],
"ok" : 1
}
这告诉我,我平均每个个人资料有 4 个问题。