我有多个文档,其中包含300名学生的相同studId和month。
在每个文档中,它都有名为marks的数组,如下所示:
{
"_id" : ObjectId("575953d49b315b14249e8bf4"),
"studID" : "1369",
"month" : "2016-1",
"marks" : [
{
"subType": "Optional",
"marks": 30
},
{
"subType": "Optional" ,
"marks": 35
},
{
"subType": "compulsory",
"marks": 30
},
{
"subType": "Optional",
"marks": 35
}
]
},
{
"_id" : ObjectId("575953d49b315b14249abcfr"),
"studID" : "1369",
"month" : "2016-2",
"marks" : [
{
"subType": "Optional",
"marks": 30
},
{
"subType": "Optional",
"marks": 35
},
{
"subType": "compulsory",
"marks": 30
},
{
"subType": "Optional" ,
"marks": 35
}
]
}我想找选修课和必修课的month wise total marks。
结果应该是:
"studID" : "1369":
"month" : "2016-1"
"subType":"Optional","optional toatal":100
"subType":"compulsory" "compulsorytoatal":30
"month" : "2016-2"
"subType":"Optional","optional toatal":100
"subType":"compulsory" "compulsorytoatal":30我已经尝试了以下查询:
db.calculatedmarks.aggregate([
{$match:{ "studID" : "1369" }},
{$unwind: "$marks"},
{$match:{ "marks.subType":'compulsory' }},
{$group:{ _id:null, total:{ $sum:"$marks.marks" } }}
]) 但它给出了subtype compulsory的所有月份的总分。
发布于 2016-06-10 15:01:20
你想要什么样的输出还不是很清楚。您可能希望阅读MongoDB手册中有关$group运算符的更多信息。请记住,$group使用_id属性进行分组,因此如果您将_id设置为一个常量值,比如null,您将只返回一行。这里有一些你可以尝试的东西:
db.calculatedmarks.aggregate([
{ $unwind: "$marks" },
{
$group: {
_id: { studID: "$studID", month:"$month", subType:"$marks.subType" },
total: {$sum: "$marks.marks"}
}
}
])要获得此输出,请执行以下操作:
{
"_id" : {
"studID" : "1369",
"month" : "2016-1",
"subType" : "Optional"
},
"total" : 100
} 将此代码附加到管道中:
{
$group: {
_id: { studID: "$_id.studID", month:"$_id.month" },
subType: {$push: {subType: "$_id.subType", total:"$total"}}
}
},
{
$group: {
_id: "$_id.studID",
month: {$push: {month: "$_id.month", subType: "$subType"}}
}
}要获得类似以下内容的输出:
{
"_id" : "1369",
"month" : [
{
"month" : "2016-1",
"subType" : [
{
"subType" : "Optional",
"total" : 100
},
{
"subType" : "compulsory",
"total" : 30
}
]
}, https://stackoverflow.com/questions/37740389
复制相似问题