mongodb(一)——mapreduce

Map-Reduce是一种计算模型,简单的说就是将大批量的工作(数据)分解(MAP)执行,然后再将结果合并成最终结果(REDUCE)。
MongoDB提供的Map-Reduce非常灵活,以下是常用样例:

1、mongodb mapreduce 查询集合中所有字段类型

db.runCommand({
    "mapreduce" : "collectionName",
    "map" : function () {
        for (var key in this) { 
            emit(key, this); 
        }
    },
    "reduce" :function (key, values) {
        var e = values[1][key];
        var r = typeof e;
       // js判断数据类型 方法二
       // var a = Object.prototype.toString;
       // var r = a.call(e);
        return r;
    }, 
    "out": { inline : 1}
})

2、java 执行mongodb mapreduce 的例子

import java.net.UnknownHostException;
 
import com.mongodb.DB;
import com.mongodb.DBCollection;
import com.mongodb.DBObject;
import com.mongodb.MapReduceCommand;
import com.mongodb.MapReduceOutput;
import com.mongodb.MongoClient;
 
/**
 * Java + MongoDB MapReduce  count()
 * 
 */
public class MapReduce {
 
  public static void main(String[] args) {
 
    // Connect to mongodb
    MongoClient mongo = null;
    try {
        mongo = new MongoClient("localhost", 27017);
    } catch (UnknownHostException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
 
    // get database 
    // if database doesn't exists, mongodb will create it for you
    DB db = mongo.getDB("test");
 
    // get collection
    // if collection doesn't exists, mongodb will create it for you
    DBCollection collection = db.getCollection("person");
 
    String map ="function () {"+
            "emit('size', {count:1});"+
    "}";
 
    String reduce = "function (key, values) { "+
        " total = 0; "+
        " for (var i in values) { "+
            " total += values[i].count; "+
        " } "+
        " return {count:total} }";
 
    MapReduceCommand cmd = new MapReduceCommand(collection, map, reduce,
                     null, MapReduceCommand.OutputType.INLINE, null);
 
    MapReduceOutput out = collection.mapReduce(cmd);
 
    for (DBObject o : out.results()) {
        System.out.println(o.toString());
    }
    System.out.println("Done");
 
  }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • MongoDB的聚合操作主要是对数据的批量处理。一般都是将记录按条件分组之后进行一系列求最大值,最小值,平均值的简...
    AaronSimon阅读 1,913评论 0 0
  • MapReduce介绍 MongoDB 中的MapReduce 使用JavaScript来作为查询语言,因此能表达...
    持续进步者阅读 799评论 0 0
  • MapReduce 使用JavaScript作为“查询语言”。因此它能够表达任意复杂的逻辑。然而,这种强大是有代价...
    AQ王浩阅读 457评论 0 3
  • 初次试用了一下mongodb的mapreduce方法,总结了一些粗浅的认识,记录如下: 下面例子中,documen...
    menglj阅读 173评论 0 0
  • 在做聚合运算的时候,Map-reduce是个不错的选择;顾名思义:Map-reduce主要通过实现Map函数与re...
    小直阅读 4,704评论 1 47