首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >我在MongoDB中使用MapReduce时出错

我在MongoDB中使用MapReduce时出错
EN

Stack Overflow用户
提问于 2014-09-11 09:53:37
回答 1查看 126关注 0票数 0

首先,采用32位windows XP操作系统,NoSQL数据库采用MongoDB,编辑程序采用Eclipse。我从学校得到了一份关于MapReduce的作业,所以我决定使用mapreduce来找出有多少适龄工作人口和非工作人口。我使用以下代码输入数据并另存为Insert.java:

代码语言:javascript
复制
package mongox;

 import com.mongodb.BasicDBObject;
 import com.mongodb.Mongo;
 import com.mongodb.DB;
 import com.mongodb.DBCollection;

 public class Insert {
   public static void main(String[] args) { 
    try{ 
         Mongo mongox = new Mongo(); 
         DB db = mongox.getDB("DBPublic"); 
         DBCollection koleksi = db.getCollection("lancestorvalley"); 
         BasicDBObject object = new BasicDBObject(); 

         object = new BasicDBObject(); 
         object.put("NIK", "7586930211");
         object.put("Name", "Richard Bou");
         object.put("Sex", "M");
         object.put("Age", "31");
         object.put("Blood", "A");
         object.put("Status", "Married");
         object.put("Education", "Bachelor degree");
         object.put("Employment", "Labor");
         koleksi.insert(object);
    } 
    catch(Exception e){ 
         System.out.println(e.toString());
    } 
 } 
}

我将此代码用于MapReduce并另存为Mapreduce.java:

代码语言:javascript
复制
   package mongox;

    import com.mongodb.DB;
    import com.mongodb.DBCollection;
    import com.mongodb.DBObject;
    import com.mongodb.MapReduceCommand;
    import com.mongodb.MapReduceOutput;
    import com.mongodb.Mongo;

    public class Mapreduce {
    public static void main(String[] args) { 
    try{ 
         Mongo mongox = new Mongo("localhost", 27017); 
         DB db = mongox.getDB("DBPublic"); 
         DBCollection koleksi = db.getCollection("lancestorvalley"); 

         String map = "function() { "+
         "var category; " + 
         "if ( this.Age >= 15 && this.Age <=59 ) "+ 
         "category = 'Working-Age Population'; " +
         "else " +
         "category = 'Non-Working-Age Population'; "+ 
         "emit(category, {Nama: this.Nama});}";

         String reduce = "function(key, values) { " +
         "var sum = 0; " +
         "values.forEach(function(doc) { " +
         "sum += 1; "+ 
         "}); " +
         "return {data: sum};} ";

         MapReduceCommand cmd = new MapReduceCommand(koleksi, map, reduce,
                 null, MapReduceCommand.OutputType.INLINE, null);
         MapReduceOutput out = koleksi.mapReduce(cmd);   

         for (DBObject o : out.results()) {
             System.out.println(o.toString());
             }
    } 
    catch(Exception e){ 
        e.printStackTrace();; 
    }
    }
  }

我已经输入了5000个数据,当我运行Mapreduce.java时,输出是:

代码语言:javascript
复制
  { "_id" : "Non-Working-age population" , "value" : { "data" : 41.0}}
  { "_id" : "Working-age Population" , "value" : { "data" : 60.0}}

我在Mapreduce.java中的代码有问题吗?为什么只有在数据约为5000的情况下,输出才是这样的?希望有人能帮我,谢谢各位

EN

回答 1

Stack Overflow用户

发布于 2014-09-11 21:16:55

MongoDB文档的显式状态如下,这可能是导致意外行为的原因:

代码语言:javascript
复制
Platform Support

Starting in version 2.2, MongoDB does not support Windows XP. Please use a more recent version of Windows to use more recent releases of MongoDB.

此外:

代码语言:javascript
复制
MongoDB for Windows 32-bit runs on any 32-bit version of Windows newer than Windows XP. 32-bit versions of MongoDB are only intended for older systems and for use in testing and development systems. 32-bit versions of MongoDB only support databases smaller than 2GB.
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25777805

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档