MongoDB nested group by query



我想计算正确,不正确且无罪的问题计数。我的值零。

查询 -

db.studentreports.aggregate([
{ $match: { 'groupId': 314 } },
{ $unwind: '$questions' },
{ $group: 
    {
      _id: {
       dateTimeStamp: '$dateTimeStamp',
       customerId: '$customerId'
      },
      questions : { $push: '$questions' },
      unttempted : { $sum : { $eq: ['$questions.status',0]}},
      correct : { $sum : { $eq: ['$questions.status',1]}}, 
      incorrect : { $sum : { $eq: ['$questions.status',2]}}, 
      Total: { $sum: 1 }      
    }
}
])

模式结构 -

{
    "_id" : ObjectId("59fb46ed560e1a2fd5b6fbf4"),    
    "customerId" : 2863318,
    "groupId" : 309,  
    "questions" : [ 
        {
            "questionId" : 567,
            "status" : 0,            
            "_id" : ObjectId("59fb46ee560e1a2fd5b700a4"),           
        }, 
        {
            "questionId" : 711,
            "status" : 0,           
            "_id" : ObjectId("59fb46ee560e1a2fd5b700a3")           
        }, 
....

值不超空,正确和不正确的值 -

" unttempted":0, "正确":0, "不正确":0, "总计":7558.0

基于DateTime和CustomerID需要组。一个正确的查询可以吗?谢谢。

您只想在满足某个条件时才总和这些字段。您只需要像这样重写您的组语句:

{ $group: 
    {
      _id: {
       dateTimeStamp: '$dateTimeStamp',
       customerId: '$customerId'
      },
      questions : { $push: '$questions' },
      unttempted : { $sum : {$cond:[{ $eq: ['$questions.status',0]}, 1, 0]}},
      correct : { $sum : {$cond:[{ $eq: ['$questions.status',1]}, 1, 0]}}, 
      incorrect : { $sum : {$cond:[{ $eq: ['$questions.status',2]}, 1, 0]}},
      Total: { $sum: 1 }      
    }
}

查看文档$eq$eq比较并返回对或错。因此,您的$sum无法对此结果做任何事情

最新更新