나는이 같은, 내가 몽고 집계 파이프 라인 내부에 사용하려는 JS 객체 norm
있습니다mongodb 집계 파이프 라인에서 Javascript 객체를 사용하는 방법은 무엇입니까?
var norm = {
1: 1,
2: 1.16,
3: 1.413,
4: 1.622,
5: 1.6,
6: 1.753,
7: 3.001,
8: 2.818,
9: 3.291,
10: 2.824,
11: 2.993,
12: 2.699,
13: 1.099,
14: 1.035,
15: 1.172,
16: 1.013,
17: 0.9936,
18: 1.069
};
db.mycoll.aggregate([
{$match :
{"_id.day" : ISODate("2014-06-19T00:00:00.000Z"),
"_id.lt" : "l",
"_id.rt" : "rltdlsts",
"_id.m": false }
},
{$unwind: '$value.rl'},
{$match: {'value.rl.p': {$gte: 1, $lte: 18} } },
{$group: {_id: '$value.rl.a',
v: {$sum: '$value.rl.v'},
nv: { $sum: { $multiply: [ norm['$value.rl.p'], '$value.rl.v' ] } },
c: {$sum: '$value.rl.c'}
}},
{$project: {
_id: "$_id",
'v': "$v",
'c': "$c",
'nv': "$nv"
}
},
{$sort: {'_id': 1}}
])
이 같은 결과를 얻을, nv
은 항상 0입니다 :
{
"result" : [
{
"_id" : 1,
"v" : 89172,
"nv" : 0,
"c" : 604
},
{
"_id" : 4,
"v" : 67872,
"nv" : 0,
"c" : 296
},
{
"_id" : 5,
"v" : 33999,
"nv" : 0,
"c" : 13
},
{
"_id" : 6,
"v" : 4727,
"nv" : 0,
"c" : 6
},
{
"_id" : 8,
"v" : 913118,
"nv" : 0,
"c" : 14055
},
{
"_id" : 9,
"v" : 204099,
"nv" : 0,
"c" : 3021
},
{
"_id" : 11,
"v" : 151711,
"nv" : 0,
"c" : 1075
},
{
"_id" : 12,
"v" : 196369,
"nv" : 0,
"c" : 601
},
{
"_id" : 13,
"v" : 277705,
"nv" : 0,
"c" : 2302
},
{
"_id" : 14,
"v" : 64005,
"nv" : 0,
"c" : 970
},
{
"_id" : 15,
"v" : 54558,
"nv" : 0,
"c" : 326
},
{
"_id" : 16,
"v" : 74576,
"nv" : 0,
"c" : 305
},
{
"_id" : 17,
"v" : 1144,
"nv" : 0,
"c" : 1
},
{
"_id" : 18,
"v" : 1023,
"nv" : 0,
"c" : 0
},
{
"_id" : 19,
"v" : 54511,
"nv" : 0,
"c" : 98
},
{
"_id" : 20,
"v" : 674,
"nv" : 0,
"c" : 0
},
{
"_id" : 21,
"v" : 3359,
"nv" : 0,
"c" : 4
},
{
"_id" : 22,
"v" : 496402,
"nv" : 0,
"c" : 3786
},
{
"_id" : 23,
"v" : 293212,
"nv" : 0,
"c" : 1904
},
{
"_id" : 24,
"v" : 764087,
"nv" : 0,
"c" : 8847
},
{
"_id" : 25,
"v" : 291358,
"nv" : 0,
"c" : 7012
},
{
"_id" : 28,
"v" : 2933,
"nv" : 0,
"c" : 27
}
],
"ok" : 1
}
방법 이 문제를 해결하려면?
파이프 라인이 한 번 평가 된 후 'norm'을 사용할 수없는 실행을 위해 서버로 전송되기 때문에 그렇게 할 수 없습니다. Map-Reduce가 가장 좋은 방법 일 것입니다. – JohnnyHK
오른쪽, 당신이하는 일을 정확히 할 수는 없지만 '$ value.rl.p'의 값에 따라 올바른 승수를 사용하기 위해 조건식을 사용하여 집계 파이프 라인을 설정할 수 있습니다. 하지만 프로그래밍 방식으로 수행 할 수 있습니다. –
Thx, @JohnnyHK MR이 내 출구 : – arun