如何在MongoDB中計算特定欄位的平均值?


要計算特定欄位的平均值,請將aggregate()與$avg結合使用。讓我們建立一個包含文件的集合−

> db.demo214.insertOne({"Marks":56,"Name":"David"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e3e319403d395bdc2134705")
}
> db.demo214.insertOne({"Marks":86,"Name":"Bob"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e3e319c03d395bdc2134706")
}
> db.demo214.insertOne({"Marks":78,"Name":"Carol"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e3e31a403d395bdc2134707")
}

在find()方法的幫助下從集合中顯示所有文件−

> db.demo214.find();

這將產生以下輸出−

{ "_id" : ObjectId("5e3e319403d395bdc2134705"), "Marks" : 56, "Name" : "David" }
{ "_id" : ObjectId("5e3e319c03d395bdc2134706"), "Marks" : 86, "Name" : "Bob" }
{ "_id" : ObjectId("5e3e31a403d395bdc2134707"), "Marks" : 78, "Name" : "Carol" }

以下是MongoDB中計算特定欄位平均值的查詢−

> db.demo214.aggregate(
...   [
...      {
...         $group:
...         {
...
...            "_id":"_id",
...            AverageValue: { $avg: "$Marks" }
...         }
...      }
...   ]
...)

這將產生以下輸出

{ "_id" : "_id", "AverageValue" : 73.33333333333333 }

更新於:30-Mar-2020

3K+ 瀏覽量

開啟你的 職業生涯

透過完成課程進行認證

開始
廣告
© . All rights reserved.