- 2024-02-14 15:22:22
- 2422 热度
- 0 评论
玩过 Hadoop 的小伙伴对 MapReduce 应该不陌生,MapReduce 的强大且灵活,它可以将一个大问题拆分为多个小问题,将各个小问题发送到不同的机器上去处理,所有的机器都完成计算后,再将计算结果合并为一个完整的解决方案,这就是所谓的分布式计算。本文我们就来看看 MongoDB 中 MapReduce 的使用。
mapReduce
MongoDB 中的 MapReduce 可以用来实现更复杂的聚合命令,使用 MapReduce 主要实现两个函数:map 函数和 reduce 函数,map 函数用来生成键值对序列, map 函数的结果作为 reduce 函数的参数,reduce 函数中再做进一步的统计,比如我的数据集如下:
1 |
{"_id" : ObjectId("59fa71d71fd59c3b2cd908d7"),"name" : "鲁迅","book" : "呐喊","price" : 38.0,"publisher" : "人民文学出版社"} |
假如我想查询每位作者所出的书的总价,操作如下:
1 |
var map=function(){emit(this.name,this.price)} |
emit 函数主要用来实现分组,接收两个参数,第一个参数表示分组的字段,第二个参数表示要统计的数据,reduce 来做具体的数据处理操作,接收两个参数,对应 emit 方法的两个参数,这里使用了 Array 中的 sum 函数对 price 字段进行自加处理,options 中定义了将结果输出的集合,届时我们将在这个集合中去查询数据,默认情况下,这个集合即使在数据库重启后也会保留,并且保留集合中的数据。查询结果如下:
1 |
{ |
再比如我想查询每位作者出了几本书,如下:
1 |
var map=function(){emit(this.name,1)} |
查询结果如下:
1 |
{ |
将每位作者的书列出来,如下:
1 |
var map=function(){emit(this.name,this.book)} |
结果如下:
1 |
{ |
比如查询每个人售价在 ¥40 以上的书:
1 |
var map=function(){emit(this.name,this.book)} |
query 表示对查到的集合再进行筛选。
结果如下:
1 |
{ |
runCommand实现
我们也可以利用 runCommand 命令来执行 MapReduce。格式如下:
1 |
db.runCommand( |
含义如下:
参数 | 含义 |
---|---|
mapReduce | 表示要操作的集合 |
map | map函数 |
reduce | reduce函数 |
finalize | 最终处理函数 |
out | 输出的集合 |
query | 对结果进行过滤 |
sort | 对结果排序 |
limit | 返回的结果数 |
scope | 设置参数值,在这里设置的值在map、reduce、finalize函数中可见 |
jsMode | 是否将map执行的中间数据由javascript对象转换成BSON对象,默认为false |
verbose | 是否显示详细的时间统计信息 |
bypassDocumentValidation | 是否绕过文档验证 |
collation | 其他一些校对 |
如下操作,表示执行 MapReduce 操作并对统计的集合限制返回条数,限制返回条数之后再进行统计操作,如下:
1 |
var map=function(){emit(this.name,this.book)} |
执行结果如下:
1 |
{ |
小伙伴们看到,鲁迅有一本书不见了,就是因为 limit 是先限制集合返回条数,然后再执行统计操作。
finalize 操作表示最终处理函数,如下:
1 |
var f1 = function(key,reduceValue){var obj={};obj.author=key;obj.books=reduceValue; return obj} |
f1 第一个参数 key 表示 emit 中的第一个参数,第二个参数表示 reduce 的执行结果,我们可以在 f1 中对这个结果进行再处理,结果如下:
1 |
{ |
scope 则可以用来定义一个在 map、reduce 和 finalize 中都可见的变量,如下:
1 |
var f1 = function(key,reduceValue){var obj={};obj.author=key;obj.books=reduceValue;obj.sang=sang; return obj} |
执行结果如下:
1 |
{ |
好了,MongoDB 中的 MapReduce 我们就先说到这里,小伙伴们有问题欢迎留言讨论。
参考资料:
- 《MongoDB权威指南第2版》
- mongodb mapreduce小试
- mongoDB–mapreduce用法详解(未找到原始出处)
- Spring(403)
- Boot(208)
- Spring Boot(187)
- Java(82)
- Cloud(82)
- Spring Cloud(82)
- Security(60)
- Spring Security(54)
- Boot2(51)
- Spring Boot2(51)
- Redis(31)
- SQL(29)
- Mysql(25)
- IDE(24)
- Dalston(24)
- mongoDB(22)
- MVC(22)
- JDBC(22)
- IDEA(22)
- Web(21)
- CLI(20)
- Alibaba(19)
- SpringMVC(19)
- SpringBoot(17)
- Docker(17)
- Git(16)
- Eclipse(16)
- Vue(16)
- JPA(15)
- Apache(15)
- ORA(15)
- Tomcat(14)
- Linux(14)
- HTTP(14)
- Mybatis(14)
- Oracle(14)
- jdk(14)
- OAuth(13)
- Nacos(13)
- Pro(13)
- XML(13)
- JdbcTemplate(13)
- JSON(12)
- OAuth2(12)
- Data(12)
- int(11)
- Myeclipse(11)
- stream(11)
- not(10)
- Bug(10)
- maven(9)
- Map(9)
- Hystrix(9)
- ast(9)
- session(8)
- Window(8)
- Swagger(8)
- APP(8)
- Bit(8)
- API(8)
- Cache(7)
- File(7)
- IntelliJ(7)
- mail(7)
- windows(7)
- too(7)
- HTML(7)
- Github(7)
- JavaMail(7)
- WebFlux(6)
- JSP(6)
- Bean(6)
- error(6)
- nginx(6)
- Server(6)
- ueditor(6)
- jar(6)
- ehcache(6)
- UDP(6)
- RabbitMQ(6)
- star(6)
- and(6)
- Excel(6)
- Log4J(6)
- pushlet(6)
- apt(6)
- read(6)
- Freemarker(6)
- Controller(5)
- swagger2(5)
- ldquo(5)
- input(5)
- Servlet(5)
- Config(5)
- discuz(5)
- Emlog(5)
- are(5)
- SVN(5)
- for(5)
- DOM(5)