1
薩姆數組元素我有c
陣列下列集合中的每個文件MongoDB中聚合
{
{
id: 1,
k: 2.2,
type: "dog",
c: [ {parentId:1, p:2.2}, {parentId:1, p:1.4} ]
},
{
id: 2,
k: 4.3,
type:"cat",
c: [ {parentId:2, p:5.2}, {parentId:2, p:4.5} ]
}
}
parentId
在c
每個子文檔內的內部是包含文件的ID。
我想將所有文檔按type
分組,並且在每個組中知道總計k
以及所有組中的所有p
之和。
當前我在小組階段中總結k
,但在應用程序結果數組中求和p
。我想在DB中做p
的求和!
這是我做的現在:
db.myCol.aggregate([
{
$group: {
_id: { type: '$type'},
k: {$sum: '$k'}, // sum k values, very easy!
// p: {$sum: '$c.0.p'} <==== Does not work, too
c: {$addToSet: '$c'} // add to each group all c arrays of group's members
}
}
], function(err, res) {
// go over c-arrays and sum p values
var accP = 0; // accumulator for p values
for (var i=0; i<res.length; i++) {
var c = res[i].c;
for (var j=0;j<c.length; j++) {
var c2 = c[j];
for (var k=0; k<c2.length; k++) { // finally got to objects c array
accP += c2[k].p;
}
}
res[i].c = accP; // replace array with accumulated p value
}
});