如何用 MongoDB 聚合来获得分数平均值?


使用 $avg 操作符和聚合框架。我们首先使用一个带有文档的新集合。此处,一个字段是 StudentScore −

> db.averageReturiningNullDemo.insertOne(
   {"StudentDetails" : { "StudentScore" : 89 }
});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5ce9822e78f00858fb12e927")
}
> db.averageReturiningNullDemo.insertOne(
   {"StudentDetails" : { "StudentScore" : 34 }
});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5ce9822e78f00858fb12e928")
}
> db.averageReturiningNullDemo.insertOne(
   {"StudentDetails" : { "StudentScore" : 78 }
});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5ce9822e78f00858fb12e929")
}

以下查询使用 find() 方法显示集合中的所有文档 −

> db.averageReturiningNullDemo.find().pretty();

这将生成以下输出 −

{
   "_id" : ObjectId("5ce9822e78f00858fb12e927"),
   "StudentDetails" : {
      "StudentScore" : 89
   }
}
{
   "_id" : ObjectId("5ce9822e78f00858fb12e928"),
   "StudentDetails" : {
      "StudentScore" : 34
   }
}
{
   "_id" : ObjectId("5ce9822e78f00858fb12e929"),
   "StudentDetails" : {
      "StudentScore" : 78
   }
}

以下查询用于获取平均值 −

> db.averageReturiningNullDemo.aggregate([
   {
      "$group": {
         "_id": null,
         "StudentScoreAverage": {
            "$avg": "$StudentDetails.StudentScore"
         }
      }
   }
]);

这将生成以下输出 −

{ "_id" : null, "StudentScoreAverage" : 67 }

更新时间:2019 年 7 月 30 日

371 次浏览

开启你的 职业生涯

完成课程获取认证

开始
广告
© . All rights reserved.