在Java中实现MongoDB的Group功能

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介:

在非关系型数据库MongoDB中,并没有任何现成的框架可以像SQL那样通过Group By就轻松实现数据库的分组功能。如果我们想要实现MongoDBGroup功能,就必须写原生态的NO-SQL 查询语句来实现Group功能,这样既费时又费力,而且很容易出错,本文提供了一个封装的接口来实现MongoDBGroup功能,让程序员从此不再为MongoDBGroup而发愁。


接口方法如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
/**
      * keyColumn : new String[]{"xxxName","xxxType"} <br>
      * condition : 查询条件 ,可为空<br>
      * initial : 分组统计初始变量,为空时自动为每列提供初始变量<br>
      * reduce : 记录处理function<br>
      * finalize : finalize函数,可为空 <br>
      */
     public  BasicDBList group(String[] keyColumn, DBObject condition,
             DBObject initial, String reduce, String finalize) {
         DBCollection coll = getCollection();
         DBObject key =  new  BasicDBObject();
         for  ( int  i =  0 ; i < keyColumn.length; i++) {
             key.put(keyColumn[i],  true );
         }
         condition = (condition ==  null ) ?  new  BasicDBObject() : condition;
         if  (StringUtils.isEmpty(finalize)) {
             finalize =  null ;
         }
         if  (initial ==  null ) {       //定义一些初始变量
             initial =  new  BasicDBObject();
             for  ( int  i =  0 ; i < keyColumn.length; i++) {
                 DBObject index =  new  BasicDBObject();
                 index.put( "count" 0 );
                 index.put( "sum" 0 );
                 index.put( "max" 0 );
                 index.put( "min" 0 );
                 index.put( "avg" 0 );
                 index.put( "self" "" );
                 initial.put(keyColumn[i], index);
             }
         }
         BasicDBList resultList = (BasicDBList) coll.group(key, condition,
                 initial, reduce, finalize);
         return  resultList;
     }


实现案例:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
//任务统计
     @Action (value =  "getTaskStatistic" , results = {  @Result (name =  "success" , type =  "json" , params = {
             "includeProperties" "jsonResult"  }) })
     public  String getTaskStatistic() {
         DBObject initial =  new  BasicDBObject();
         DBObject index =  new  BasicDBObject();
         index.put( "count" 0 );
         index.put( "taskStatus" "" );
         initial.put( "taskStatus" , index);
                      
         String reduce =  "function (doc, out) { "
                     " out.taskStatus.count = out.taskStatus.count+=1; "
                     " out.taskStatus.inspectStatus = doc.taskStatus;"
                 "}" ;
         BasicDBList group = (BasicDBList) taskStatusService.group( new  String[] {  "taskStatus" },  null , initial, reduce,  null );
                      
         this .jsonResult = group.toString();
         return  SUCCESS;
     }

返回数据:

1
[ { "taskStatus" : { "count" : 4.0 , "taskStatus" : "Finished"}} , { "taskStatus" : { "count




本文转自 genuinecx 51CTO博客,原文链接:http://blog.51cto.com/favccxx/1310986,如需转载请自行联系原作者

相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。 &nbsp; 相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
目录
相关文章
|
29天前
|
安全 Java 测试技术
🎉Java零基础:全面解析枚举的强大功能
【10月更文挑战第19天】本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
104 60
|
17天前
|
Java
Java 8 引入的 Streams 功能强大,提供了一种简洁高效的处理数据集合的方式
Java 8 引入的 Streams 功能强大,提供了一种简洁高效的处理数据集合的方式。本文介绍了 Streams 的基本概念和使用方法,包括创建 Streams、中间操作和终端操作,并通过多个案例详细解析了过滤、映射、归并、排序、分组和并行处理等操作,帮助读者更好地理解和掌握这一重要特性。
25 2
|
2月前
|
NoSQL Java 数据库连接
MongoDB Java
10月更文挑战第18天
19 3
|
2月前
|
Java 程序员
在Java编程中,关键字不仅是简单的词汇,更是赋予代码强大功能的“魔法咒语”。
【10月更文挑战第13天】在Java编程中,关键字不仅是简单的词汇,更是赋予代码强大功能的“魔法咒语”。本文介绍了Java关键字的基本概念及其重要性,并通过定义类和对象、控制流程、访问修饰符等示例,展示了关键字的实际应用。掌握这些关键字,是成为优秀Java程序员的基础。
25 3
|
2月前
|
Java 数据安全/隐私保护
Java ffmpeg 实现视频加文字/图片水印功能
【10月更文挑战第22天】在 Java 中使用 FFmpeg 实现视频加文字或图片水印功能,需先安装 FFmpeg 并添加依赖(如 JavaCV)。通过构建 FFmpeg 命令行参数,使用 `drawtext` 滤镜添加文字水印,或使用 `overlay` 滤镜添加图片水印。示例代码展示了如何使用 JavaCV 实现文字水印。
|
2月前
|
Java
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
58 2
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
|
2月前
|
机器学习/深度学习 算法 Java
通过 Java Vector API 利用 SIMD 的强大功能
通过 Java Vector API 利用 SIMD 的强大功能
47 10
|
2月前
|
Oracle 安全 Java
Java 22 为开发人员带来了重大增强功能
Java 22 为开发人员带来了重大增强功能
40 9
|
2月前
|
Java
让星星⭐月亮告诉你,jdk1.8 Java函数式编程示例:Lambda函数/方法引用/4种内建函数式接口(功能性-/消费型/供给型/断言型)
本示例展示了Java中函数式接口的使用,包括自定义和内置的函数式接口。通过方法引用,实现对字符串操作如转换大写、数值转换等,并演示了Function、Consumer、Supplier及Predicate四种主要内置函数式接口的应用。
27 1
|
2月前
|
存储 JSON NoSQL
Java 中MongoDB的使用
Java 中MongoDB的使用
16 2