Mongoaggregate:返回数组值的总平均值

bed*_*dow 5 arrays average mongodb

我在 mongodb 中有这个数据

{ 
  "name": "FooBar",
  "__v": 0,
  "user_rating": [
  {
    "date": "2017-06-02T16:19:32.002Z",
    "user_rating": 5,
  },
  {
    "date": "2017-06-02T16:19:46.803Z",
    "user_rating": 3,
  },
  {
    "date": "2017-06-02T16:20:01.244Z",
    "user_rating": 5,
  },
  {
    "date": "2017-06-02T16:15:54.673Z",
    "user_rating": 3,
  },
  {
    "date": "2017-06-02T16:53:42.489Z",
    "user_rating": 5,
  }
 ]
}
Run Code Online (Sandbox Code Playgroud)

我需要过滤它以显示商店名称、平均评分、评分总数以及有多少 5 评分、多少 4 评分等。

这就是我所期待的:

[
  {
    "_id":"FooBar",
    "countRating":5,
    "averageRating":4.2,
    "ratings": [
       {"num":3,"count":2},
       {"num":5,"count":3}
     ]
  }
 ]
Run Code Online (Sandbox Code Playgroud)

但是,我似乎无法获得averageRating - 相反,我获得了每个评分的两个总和的平均值。

这是我的 Mongo 查询:

 db.collection.aggregate([
      {
        $match: {"name": "FooBar"}
      },
      {
          $unwind: "$user_rating"
      },
      {
        $match: {"name": "FooBar"}
      },
        {
          $group: {
            _id: {
              "name": "$name",
              "rating": "$user_rating.user_rating"
            },
            averageRating: {$avg: "$user_rating.user_rating"},
            countRating: {$sum: 1}
        }
      },
      {
        $group: {
          _id: "$_id.name",
          countRating: {"$sum": "$totalRatings"},
          averageRating: {"$avg": "$averageRating"},
          "rating": {
            "$push": {
              "num": "$_id.rating",
              "count": "$totalRatings"
            }
          },
        }
      }]);
Run Code Online (Sandbox Code Playgroud)

谁能帮忙算一下这里的总体平均值吗?谢谢!!

Ser*_*kiy 3

db.collection.aggregate([
      { $match: {"name": "FooBar"} },
      { $unwind: "$user_rating" },
      {
          $group: {
              _id : "$name",
              avg: {$avg: "$user_rating.user_rating" },
              ratings: {$push: "$user_rating.user_rating" }
          }
      },
      { $unwind: "$ratings" },
      { 
          $group: {
              _id: { name: "$_id", num: "$ratings", avg: "$avg" },
              count: { $sum: 1 }              
          }
      },
      {
          $group: {
              _id: { name: "$_id.name", avg: "$_id.avg" },
              ratings: { $push: { num: "$_id.num", count: "$count" }}
          }
      },
      { $project: {_id:0, name:"$_id.name", averageRating: "$_id.avg", ratings: 1}}
 ])
Run Code Online (Sandbox Code Playgroud)

我在这里使用了额外的分组来计算总平均评分。然后我展开结果并在分组键中传递计算出的平均值。

输出:

{
    "name" : "FooBar",
    "averageRating" : 4.2,
    "ratings" : [ 
        {
            "num" : 3,
            "count" : 2
        }, 
        {
            "num" : 5,
            "count" : 3
        }
    ]
}
Run Code Online (Sandbox Code Playgroud)