javascript,// 定义映射函数,var mapFunction = function() {, emit(this.category, this.value);,};,,// 定义规约函数,var reduceFunction = function(key, values) {, return Array.sum(values);,};,,// 使用MapReduce,db.collection.mapReduce(, mapFunction,, reduceFunction,, { out: "outputCollection" },);,
`,,在这个例子中,
mapFunction 将每个文档的
category 字段作为键,
value 字段作为值发出。
reduceFunction 将所有具有相同键的值求和。MapReduce 的结果存储在名为
outputCollection` 的新集合中。统计每个用户购买的产品数量
假设有一个集合test
,其中存储了三个用户购买的产品数据,每个文档包含用户的姓名、产品ID和价格,现在需要统计每个用户购买了多少个产品。
1、Map函数:
map = function() { emit(this.user, {count: 1}); }
2、Reduce函数:
reduce = function(key, values) { var cnt = 0; values.forEach(function(val) { cnt += val.count; }); return {count: cnt}; }
3、执行MapReduce并输出结果到集合mr1
:
db.test.mapReduce(map, reduce, {out: "mr1"});
4、查看结果:
db.mr1.find();
结果示例:
{ "_id" : "Joe", "value" : { "count" : 416 } } { "_id" : "Josh", "value" : { "count" : 287 } } { "_id" : "Ken", "value" : { "count" : 297 } }
实例二:统计每个用户不同产品的购买数量
假设需要统计每个用户不同产品的购买数量。
1、Map函数:
map = function() { emit({user: this.user, sku: this.sku}, {count: 1}); }
2、Reduce函数:
reduce = function(key, values) { var cnt = 0; values.forEach(function(val) { cnt += val.count; }); return {count: cnt}; }
3、执行MapReduce并输出结果到集合mr2
:
db.test.mapReduce(map, reduce, {out: "mr2"});
4、查看结果:
db.mr2.find();
结果示例:
{ "_id" : { "user" : "Joe", "sku" : 0 }, "value" : { "count" : 103 } } { "_id" : { "user" : "Joe", "sku" : 1 }, "value" : { "count" : 106 } } { "_id" : { "user" : "Joe", "sku" : 2 }, "value" : { "count" : 102 } } ...
实例三:统计每个用户的总购买金额和产品数量
假设需要统计每个用户的总购买金额和产品数量。
1、Map函数:
map = function() { emit(this.user, {amount: this.price, count: 1}); }
2、Reduce函数:
reduce = function(key, values) { var res = {amount: 0, count: 0}; values.forEach(function(val) { res.amount += val.amount; res.count += val.count; }); return res; }
3、执行MapReduce并输出结果到集合mr3
:
db.test.mapReduce(map, reduce, {out: "mr3"});
4、查看结果:
db.mr3.find();
结果示例:
{ "_id" : "Joe", "value" : { "amount" : 41600, "count" : 416 } } { "_id" : "Josh", "value" : { "amount" : 28700, "count" : 287 } } { "_id" : "Ken", "value" : { "amount" : 29700, "count" : 297 } }
FAQs:
1、什么是MapReduce?
MapReduce是一种编程模型,用于处理和生成大数据集,它通过将任务分解为两个主要阶段(Map和Reduce)来并行处理数据,Map阶段将输入数据映射成键值对,Reduce阶段则将这些键值对聚合成最终结果,MongoDB中的MapReduce使用JavaScript编写,可以在多台服务器上并行处理数据。
2、MapReduce在MongoDB中的主要步骤是什么?
MapReduce在MongoDB中的主要步骤包括:
Map阶段:将一个操作映射到集合中的每个文档,产生Key/Value对。
Shuffle阶段:根据Key分组对文档,并为每个不同的Key生成一系列值表(List of values)。
Reduce阶段:处理值表中的元素,直到每个Key只对应一个值表,并且此值表中只有一个元素,然后将值表返回到Shuffle过程,循环处理,直到得到最终结果。
Finalize阶段(可选):在得到MR最终结果后,再进行一些数据“修剪”性质的处理。
| 阶段 | 描述 | 代码示例 |
| | | |
| Map 阶段 | 对每个输入文档执行操作,并输出键值对 | “`javascript
function() {
emit(this.category, 1); // 假设每个文档都有一个category字段
“` |
| Shuffle 阶段 | 将Map阶段输出的键值对进行重新排序,并分配到Reduce函数中 | 无需编写代码,由MongoDB内部处理 |
| Reduce 阶段 | 对相同键的所有值进行聚合操作 | “`javascript
function(key, values) {
return Array.sum(values); // 返回对应category的文档数量总和
“` |
| Finalize 阶段 | 对Reduce阶段输出的结果进行进一步处理,例如格式化输出 | “`javascript
function(result) {
return result; // 返回最终结果,无需进一步处理
“` |
完整示例代码:
db.collection.mapReduce( function() { emit(this.category, 1); // 假设每个文档都有一个category字段 }, function(key, values) { return Array.sum(values); // 返回对应category的文档数量总和 }, { out: "mapreduce_output" } // 输出结果存储在mapreduce_output集合中 );
在这个例子中,我们统计了每个category的文档数量,运行此MapReduce操作后,结果将存储在名为mapreduce_output
的集合中,你可以使用db.mapreduce_output.find()
查询该集合,查看结果。
原创文章,作者:未希,如若转载,请注明出处:https://www.kdun.com/ask/1185245.html
本网站发布或转载的文章及图片均来自网络,其原创性以及文中表达的观点和判断不代表本网站。如有问题,请联系客服处理。
发表回复