在MongoDb中聚合嵌入在值列表中的文档

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在MongoDb中聚合嵌入在值列表中的文档相关的知识,希望对你有一定的参考价值。

我有MongoDb数据如下

{
        "_id" : 7,
        "name" : "Salena Olmos",
        "scores" : [
                {
                        "type" : "exam",
                        "score" : 90.37826509157176
                },
                {
                        "type" : "quiz",
                        "score" : 42.48780666956811
                },
                {
                        "type" : "homework",
                        "score" : 67.18328596625217
                },
                {
                        "type" : "homework",
                        "score" : 96.52986171633331
                }
        ]
}

我想把“类型”的“分数”加起来:“作业”

{ "_id" : 7, "score" : 163.71314768258548} 

我使用聚合和过滤条件编写了我的查询,如下所示

db.students.aggregate([
    {     
     "$group" : 
      { 
       "_id":"$_id",
       "score":{$sum: {$filter: {
                                input: "$scores",
                                    as: "x",
                                cond: {$eq : ["$$x.type", "homework"]}
                                }
                      }
               }
      }
    }
])

但是所有它给我的总和值为“0”:

{ "_id" : 7, "score" : 0 }

请帮助我,我是MongoDb的新手,并试图通过解决一些运动问题来学习。

谢谢

答案

您可以使用以下聚合。使用$let从匹配分数中提取分数。

db.students.aggregate({
  "$project":{
    "score":{
      "$sum":{
        "$let":{
          "vars":{
            "mscores":{
              "$filter":{
                "input":"$scores",
                "as":"x",
                "cond":{"$eq":["$$x.type","homework"]}
              }
            }
          },
          "in":"$$mscores.score"
        }
      }
    }
  }
})
另一答案

我已经浏览了MongoDb文档并提出了以下解决方案

  db.students.aggregate([ 
   {$unwind: "$scores"},
   {$match:{"scores.type" : "homework"}},
   {$group : {"_id":"$_id", "score":{$sum: "$scores.score"}}}
 ])

以上是关于在MongoDb中聚合嵌入在值列表中的文档的主要内容,如果未能解决你的问题,请参考以下文章

使用聚合查询获取具有总交易计数和交易详细信息的用户列表作为嵌入文档

聚合中的mongodb $count 太慢,超过1mill。数据库中的文档

使用 MongoDB 中的文档属性过滤器获取嵌入数组中的扁平文档数组

MongoDB

如何在mongodb聚合框架中的管道阶段后加入文档

mongoDB表与表的关系及聚合管道查询