reduce 命令

db.runCommand(
{
mapReduce: <collection>,
map: <function>,
reduce: <function>,
finalize: <function>,
out: <output>,
query: <document>,
sort: <document>,
limit: <number>,
scope: <document>,
jsMode: <boolean>,
verbose: <boolean>,
bypassDocumentValidation: <boolean>
}
)
  1. mapReduce 你要做并行处理的集合名字
  2. map: 分组依据, emit(key,value) => key => group的key,value => 是你key的数组 key=25, values=【“jack","mary"]
  3. reduce: function(key,values) 里面有两个参数, 第一个参数是key:group操作的key,第二个参数是values: 我们刚才说到的 【数组】,类似group中的finalize函数。
  4. finalize: 这个呢,还是和group中的 finalize 一样,会对每组的结构进行一个最后修改。也可以不修改。
  5. out: 就是我们进行mapreduce之后,将结果存放的位置,一般是“集合类型“。
  6. query: 这个很简单,和group的query一样
  7. sort: 一样的到底,对map操作之前的文档进行排序。
  8. limit: 在map之前限制文档的个数
  9. scope: 给reduce,query之类的函数提供变量访问。
  10. 我们常用到的是: mapReduce, map,reduce, out,query,

二:我们看一下注意事项

我们还是用一个person集合,其中有name和age。

上一节课程我们将group的时候,做了一个对age进行分组的一个例子

{age:26,count:2}
{age:29,count:2}
{age:31,count:2}
  1. 第一步:插入数据源
> db.person.find()
{ "_id" : ObjectId("5678a3fc763ea69ae9780c62"), "name" : "mary", "age" : 26 }
{ "_id" : ObjectId("5678a403763ea69ae9780c63"), "name" : "jackson", "age" : 26 }
{ "_id" : ObjectId("5678a40a763ea69ae9780c64"), "name" : "john", "age" : 29 }
{ "_id" : ObjectId("5678a410763ea69ae9780c65"), "name" : "hxc", "age" : 31 }
{ "_id" : ObjectId("5678a416763ea69ae9780c66"), "name" : "mongodb", "age" : 31 }
{ "_id" : ObjectId("5678a41d763ea69ae9780c67"), "name" : "redis", "age" : 29 }
  1. 执行命令
 db.runCommand({
mapreduce:"person",
map:function(){
emit(this.age,this.name); //相当于group的key
},
reduce:function(key,values){ //{key:26,values:["mary","jackson"]}
return {"key":key,"values":values};
},
finalize:function(key,values){
return {"age":key,"count":values.length};
},
out:"t" //最终的存放结果
}) db.runCommand({
mapreduce:"person",
map:function(){
emit(this.age,this.name);
},
reduce:function(key,values){
return {"key":key,"values":values};
},
out:"t"
}) db.runCommand({
mapreduce:"person",
map:function(){
emit(this.age,this.name)
},
reduce:function(key,values){
return values.length;
},
out:"t",
finalize:function(key,values){
return values;
},
query:{"$where":function(){return this.age>28}}
})
db.person.find()
{ "_id" : ObjectId("5678a3fc763ea69ae9780c62"), "name" : "mary", "age" : 26 }
{ "_id" : ObjectId("5678a403763ea69ae9780c63"), "name" : "jackson", "age" : 26 }
{ "_id" : ObjectId("5678a40a763ea69ae9780c64"), "name" : "john", "age" : 29 }
{ "_id" : ObjectId("5678a410763ea69ae9780c65"), "name" : "hxc", "age" : 31 }
{ "_id" : ObjectId("5678a416763ea69ae9780c66"), "name" : "mongodb", "age" : 31 }
{ "_id" : ObjectId("5678a41d763ea69ae9780c67"), "name" : "redis", "age" : 29 }
db.runCommand({
... mapreduce:"person",
... map:function(){
... emit(this.age,this.name)
... },
... reduce:function(key,values){
... return {"key":key,"values":values}
... },
... out:"t"
... })
{
"result" : "t",
"timeMillis" : 20,
"counts" : {
"input" : 6,
"emit" : 6,
"reduce" : 3,
"output" : 3
},
"ok" : 1
}
db.t.find()
{ "_id" : 26, "value" : { "key" : 26, "values" : [ "mary", "jackson" ] } }
{ "_id" : 29, "value" : { "key" : 29, "values" : [ "john", "redis" ] } }
{ "_id" : 31, "value" : { "key" : 31, "values" : [ "hxc", "mongodb" ] } }

把 { "key" : 26, "values" : [ "mary", "jackson" ] } 整体的返回成一个 count就好了 。。。

{ "_id" : 26, "value" : 2 }
{ "_id" : 29, "value" : 2 }
{ "_id" : 31, "value" : 2 }

——————————————————————————————

 db.t.find()
{ "_id" : 26, "value" : { "key" : 26, "values" : [ "mary", "jackson" ] } }
{ "_id" : 29, "value" : { "key" : 29, "values" : [ "john", "redis" ] } }
{ "_id" : 31, "value" : { "key" : 31, "values" : [ "hxc", "mongodb" ] } }
db.runCommand({
... mapreduce:"person",
... map:function(){
... emit(this.age,this.name)
... },
... reduce:function(key,values){
... return values.length;
... },
... out:"t"
... })
{
"result" : "t",
"timeMillis" : 14,
"counts" : {
"input" : 6,
"emit" : 6,
"reduce" : 3,
"output" : 3
},
"ok" : 1
}
db.t.find()
{ "_id" : 26, "value" : 2 } //这个结果就是我们需要的。。。
{ "_id" : 29, "value" : 2 }
{ "_id" : 31, "value" : 2 }

我想把"_id" 替换成 "age", "value" 替换成 “count"

query条件的使用:

> db.t.find()
{ "_id" : 26, "value" : 2 }
{ "_id" : 29, "value" : 2 }
{ "_id" : 31, "value" : 2 }
> db.runCommand({
... mapreduce:"person",
... map:function(){
... emit(this.age,this.name)
... },
... reduce:function(key,values){
... return values.length;
... },
... out:"t",
... finalize:function(key,values){
... return values;
... },
... query:{"$where":function(){return this.age>28}}
... })
{
"result" : "t",
"timeMillis" : 69,
"counts" : {
"input" : 4,
"emit" : 4,
"reduce" : 2,
"output" : 2
},
"ok" : 1
}
> db.t.find()
{ "_id" : 29, "value" : 2 }
{ "_id" : 31, "value" : 2 }

mongodb--reduce并行处理框架的更多相关文章

  1. Hive数据分析——Spark是一种基于rdd(弹性数据集)的内存分布式并行处理框架,比于Hadoop将大量的中间结果写入HDFS,Spark避免了中间结果的持久化

    转自:http://blog.csdn.net/wh_springer/article/details/51842496 近十年来,随着Hadoop生态系统的不断完善,Hadoop早已成为大数据事实上 ...

  2. Morphia - mongodb之ORM框架

    一.简介 二.注解 1.@Entity 2.@Id3.@Indexed4.@Embedded5.@Transient和@Property6.@Reference 三.示例 四.参考资料 Morphia ...

  3. day96_11_28 mongoDB与scrapy框架

    一.mongodb mongodb是一个面向文档的数据库,而不是关系型数据库.不采用关系型是为了获得更好的扩展性. 它与mysql的区别在于它没有表连接,但是可以通过其他办法实现. 安装数据库. 上官 ...

  4. mongoose-面向对象操作mongodb的Nodejs框架

    介绍 无论是mysql还是mongodb,传统的与数据库交互的方式都是按照他们提供的API来写代码.它们提供的API往往不是很容易理解,而且难以记忆,如果传错了参数,写错一个符号都要查文档. ORM( ...

  5. MongoDB的ORM框架——Morphia

    1.引入pom <dependency> <groupId>org.mongodb.morphia</groupId> <artifactId>morp ...

  6. Mongodb 的ORM框架 Morphia之注解

    @Entity("bands") public class Band { @Id ObjectId id; String name; String genre; @Referenc ...

  7. Mongodb 的ORM框架 Morphia 注解 之 @Reference

    public class BlogEntry { private String title; private Date publishDate; private String body; privat ...

  8. [转]HIVE UDF/UDAF/UDTF的Map Reduce代码框架模板

    FROM : http://hugh-wangp.iteye.com/blog/1472371 自己写代码时候的利用到的模板   UDF步骤: 1.必须继承org.apache.hadoop.hive ...

  9. mean(bootstrap,angular,express,node,mongodb)通用后台框架

    学习node,我这个毫无美感的程序员在bootstrap与node的感染下,向着“全栈工程师”迈进,呵呵! 最终选择如题的技术方案,这些东东都算比较新的,网上的资料比较少,参考了不少github程序及 ...

随机推荐

  1. bzoj 4521 [ Cqoi 2016 ] 手机号码 —— 数位DP

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4521 数位DP,记录好多维状态: 写了半天,复杂得写不下去了,于是参考一下TJ... 练习简 ...

  2. (Go)05.基本数据类型和操作符

    保留的关键字段 1.Question1 package main import ( "fmt" ) func list(n int) { ; i <= n; i++ { fm ...

  3. hihoCoder 1187

    今天BC爆0了....但是日子还是要过的....要回学校毕业了~~大学就这么“荒废”了. 这个是hihoCoder的1187,比较基础的一道题. 题目链接: http://hihocoder.com/ ...

  4. PHP无限级分类实现(递归+非递归)

    <?php /** * Created by PhpStorm. * User: qishou * Date: 15-8-2 * Time: 上午12:00 */ //准备数组,代替从数据库中检 ...

  5. 前端面试:问到GET和POST两种区别

    最直观的区别就是GET把参数包含在URL中,POST通过request body传递参数. "标准答案"(本标准答案参考自w3schools): GET在浏览器回退时是无害的,而P ...

  6. File入门及路径名问题

    package com.io.file; import java.io.File; /** * @author 王恒 * @datetime 2017年4月20日 下午2:53:29 * @descr ...

  7. js动态追加的元素如何触发事件

    一般通过js或者jQuery动态添加的元素标签,通过该元素标签.class.id触发事件,是无效的.如下所示: <body> <input type="text" ...

  8. 5.20 mybatis反向生成的映射文件xml(如果需要自己定义其他sql语句时如下)

    解决mybatis-generator 生成的mapper.xml覆盖自定义sql的问题 mybatis-generator是个好工具,一建即可生成基本增删改成功能的mapper.xml.但这些是不够 ...

  9. “阻塞”与"非阻塞"与"同步"与“异步"

    链接:http://www.zhihu.com/question/19732473/answer/20851256来源:知乎 “阻塞”与"非阻塞"与"同步"与“ ...

  10. 关于MYSQL 存储过程的文章摘录

    1.      存储过程简介   我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储 ...