在Java中实现MongoDB的Group功能

简介:

在非关系型数据库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,如需转载请自行联系原作者

目录
相关文章
|
5月前
|
安全 Java API
Java中的Lambda表达式:简洁与功能的结合
Java中的Lambda表达式:简洁与功能的结合
474 211
|
5月前
|
JavaScript Java 微服务
现代化 Java Web 在线商城项目技术方案与实战开发流程及核心功能实现详解
本项目基于Spring Boot 3与Vue 3构建现代化在线商城系统,采用微服务架构,整合Spring Cloud、Redis、MySQL等技术,涵盖用户认证、商品管理、购物车功能,并支持Docker容器化部署与Kubernetes编排。提供完整CI/CD流程,助力高效开发与扩展。
626 64
|
4月前
|
存储 数据可视化 Java
Java Stream API 的强大功能
Java Stream API 是 Java 8 引入的重要特性,它改变了集合数据的处理方式。通过声明式语法,开发者可以更简洁地进行过滤、映射、聚合等操作。Stream API 支持惰性求值和并行处理,提升了代码效率和可读性,是现代 Java 开发不可或缺的工具。
104 0
Java Stream API 的强大功能
|
5月前
|
前端开发 JavaScript Java
Java 项目实战城市公园信息管理系统开发流程与实用功能实现指南
本系统基于Java开发,采用Spring Boot后端框架与Vue.js前端框架,结合MySQL数据库,构建了一个高效的城市公园信息管理系统。系统包含管理员、用户和保洁人员三大模块,涵盖用户管理、园区信息查询、订票预约、服务管理等功能,提升公园管理效率与服务质量。
197 6
|
5月前
|
安全 Java 数据库
Java 项目实战病人挂号系统网站设计开发步骤及核心功能实现指南
本文介绍了基于Java的病人挂号系统网站的技术方案与应用实例,涵盖SSM与Spring Boot框架选型、数据库设计、功能模块划分及安全机制实现。系统支持患者在线注册、登录、挂号与预约,管理员可进行医院信息与排班管理。通过实际案例展示系统开发流程与核心代码实现,为Java Web医疗项目开发提供参考。
292 2
|
6月前
|
Java API
Java API中Math类功能全景扫描
在实际使用时,这些方法的精确度和性能得到了良好的优化。当处理复杂数学运算或高精度计算时,`Math`类通常是足够的。然而,对于非常精细或特殊的数学运算,可能需要考虑使用 `java.math`包中的 `BigDecimal`类或其他专业的数学库。
144 11
|
5月前
|
机器学习/深度学习 算法 Java
Java 大视界 -- Java 大数据机器学习模型在生物信息学基因功能预测中的优化与应用(223)
本文探讨了Java大数据与机器学习模型在生物信息学中基因功能预测的优化与应用。通过高效的数据处理能力和智能算法,提升基因功能预测的准确性与效率,助力医学与农业发展。
|
6月前
|
Java API
深入解析Java API中Object类的功能
了解和合理运用 Object类的这些方法,对于编写可靠和高效的Java应用程序至关重要。它们构成了Java对象行为的基础,影响着对象的创建、识别、表达和并发控制。
126 0
|
6月前
|
消息中间件 监控 Java
借助最新技术构建 Java 邮件发送功能的详细流程与核心要点分享 Java 邮件发送功能
本文介绍了如何使用Spring Boot 3、Jakarta Mail、MailHog及响应式编程技术构建高效的Java邮件发送系统,涵盖环境搭建、异步发送、模板渲染、测试与生产配置,以及性能优化方案,助你实现现代化邮件功能。
278 0

推荐镜像

更多