Điều này chỉ đơn giản là sẽ không hoạt động như đã viết. Vấn đề quan trọng là ở đây:key: {"ResultSet.Results.state": true}
. ResultSet.Results
là một mảng. Khi bạn yêu cầu ResultSet.Results.state
bạn đang ám chỉ một số loại for
vòng lặp được thực hiện ở đây. Nhóm group
chỉ đơn giản là lệnh không có khả năng này.
Thay vào đó, hãy thử M / R sau:
map = function() {
// Note that we emit once per result
foreach(var i in ResultSet.Results) {
key = this.ResultSet.Results[i];
value = { count: 1,
quality: this.ResultSet.Results[i].quality,
avg_quality: 0
};
emit(key, value);
}
}
reduce = function(key, values) {
// note that results has same fields as emitted value
var results = { count: 0, quality: 0, avg_quality: 0 };
foreach(var i in values){
results.count += values[i].count;
results.quality += values[i].quality;
// ignore avg_quality, we don't use it
}
return results;
}
Bạn cũng sẽ phải viết một finalize
cho mức trung bình.
finalize = function(key, value) {
if (value.count > 0)
value.avg_quality = value.quality / value.count;
return value;
}