如何根據重複的 ID 在 MongoDB 中獲得評級平均值?


要在 MongoDB 中計算平均值,請使用 $avg。我們建立一個帶有文件的集合。此處,我們有重複的 ID 且每個都具有評分 −

> db.demo606.insertOne({id:1,rating:5});{
   "acknowledged" : true, "insertedId" : ObjectId("5e972dfbf57d0dc0b182d623")
}
> db.demo606.insertOne({id:1,rating:4});{
   "acknowledged" : true, "insertedId" : ObjectId("5e972dfef57d0dc0b182d624")
}
> db.demo606.insertOne({id:2,rating:3});{
   "acknowledged" : true, "insertedId" : ObjectId("5e972e09f57d0dc0b182d625")
}
> db.demo606.insertOne({id:1,rating:null});{
   "acknowledged" : true, "insertedId" : ObjectId("5e972e0ef57d0dc0b182d626")
}
> db.demo606.insertOne({id:2,rating:null});{
   "acknowledged" : true, "insertedId" : ObjectId("5e972e15f57d0dc0b182d627")
}
> db.demo606.insertOne({id:2,rating:3});{
   "acknowledged" : true, "insertedId" : ObjectId("5e972e1bf57d0dc0b182d628")
}

藉助 find() 方法從集合中顯示所有文件 −

> db.demo606.find();

這會生成以下輸出 −

{ "_id" : ObjectId("5e972dfbf57d0dc0b182d623"), "id" : 1, "rating" : 5 }
{ "_id" : ObjectId("5e972dfef57d0dc0b182d624"), "id" : 1, "rating" : 4 }
{ "_id" : ObjectId("5e972e09f57d0dc0b182d625"), "id" : 2, "rating" : 3 }
{ "_id" : ObjectId("5e972e0ef57d0dc0b182d626"), "id" : 1, "rating" : null }
{ "_id" : ObjectId("5e972e15f57d0dc0b182d627"), "id" : 2, "rating" : null }
{ "_id" : ObjectId("5e972e1bf57d0dc0b182d628"), "id" : 2, "rating" : 3 }

以下是根據重複 ID 獲取評分平均值的查詢 −

> db.demo606.aggregate(
...    [
...       { "$group": {
...          "_id": "$id",
...          "AverageRating": { "$avg": { "$ifNull": ["$rating",0 ] } }
...       }}
...    ]
... );

這會生成以下輸出 −

{ "_id" : 2, "AverageRating" : 2 }
{ "_id" : 1, "AverageRating" : 3 }

更新於:2020 年 5 月 15 日

301 次瀏覽

開啟你的 職業生涯

透過完成課程獲得認證

開始
廣告