我是靠谱客的博主 忧虑网络,最近开发中收集的这篇文章主要介绍java实现mongodb的map-reduce过程,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

String map = "function () {" 
+   " var key = this.custNo; "
+   " var value = {custNo: this.custNo,loanNo:this.loanNo,"

+   "              list:[{"
+   "                  certNo:this.list.certNo,"
+   "                  phoneNo:this.list.phoneNo,"
+   "                  phoneName:this.list.phoneName,"
+   "                  othMsg:this.list.othMsg"
+   "                  }]"
+   "              };"
+   "    emit(key, value);"
+ "}";



// reduce 函数
String reduce = "function(key, values) {"
+ " var result = {custNo:key,loanNo:null,list:[]};"
+ " values.forEach( function(value) {"
+ " result.list = result.list.concat(value.list);"
+ "     });"
+ " result.loanNo = values[0].loanNo;"
+ " return result;"
+ "}";



BasicDBObject query = new BasicDBObject();

MapReduceCommand cmd = new MapReduceCommand(calllists, map, reduce,
"out_user", MapReduceCommand.OutputType.REPLACE, query);// out_user是指定的输出数据的集合
MapReduceOutput out = calllists.mapReduce(cmd);

Object [] str_array = null;  //通过数组读取jsonstr
String jsonStr = null;     //保存最终得到的json格式

for (DBObject o : out.results()) {
str_array = o.toMap().values().toArray();
jsonStr = str_array[1].toString();
}

最后得到的JSON格式如下:

{
 "custNo": "456654",
   "loanNo": "654321",
   "list": [
    {
      "certNo": "130406199302073017",
      "phoneNo": "18583738107",
      "phoneName": "duxin",
      "othMsg":"jjj"
    },
    {
      "certNo": "654321",
      "phoneNo": "13256565544",
      "phoneName": "haha",
      "othMsg":"hahaha"
    }
  ]
}


————————————————
版权声明:本文为CSDN博主「艾慕达」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/a18716374124/article/details/74101187

最后

以上就是忧虑网络为你收集整理的java实现mongodb的map-reduce过程的全部内容,希望文章能够帮你解决java实现mongodb的map-reduce过程所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(47)

评论列表共有 0 条评论

立即
投稿
返回
顶部