最近在检索MongoDB的数据时需要用到分组操作,由于没有现成的说明文档可参考,只能是在代码中不断调试、摸索前进;目前已现实了Java对MongoDB的分组操作,并统计各个分组的数量。现通过示例详细解析,步骤如下流程所示:

(1)测试环境条件准备:MongoDB的版本为2.0.1,如下图所示

(2)测试数据源准备:MongoDB的数据源示例如下图所示

(3)测试示例过程:

  • 最初测试过程
1、示例代码
public void test(String guid) {
String groupKey = "sex"; // 按性别来分组
GroupBy groupBy = new GroupBy(groupKey);
final String COUNT = "count"; // 统计数量值的key,可以任意字符串,例如total
DBObject initial = new BasicDBObject();
initial.put(COUNT, 0); // 初始值为0
// reduce必须要定义,否则调用MongoDB的group方法时会抛出异常
String reduce = "function (document, output) { "
+ " output." + COUNT + "++; " // 统计数量值的key自增
+ "}";
// 可以不用定义finalize变量
String finalize = "function (output) {"
+ "return output;"
+ "}";
groupBy = groupBy.reduceFunction(reduce); // 必须要设置,不能为null,该函数的含义是在分组操作时定义一个操作文档的聚合函数
groupBy = groupBy.collation(null); // 设置为null吧
groupBy = groupBy.finalizeFunction(finalize); // 可以设置为null,该函数的含义是在group函数返回最终值之前,定义一个运行每个分组的结果集的函数
groupBy = groupBy.initialDocument(initial.toString()); // 初始化分组统计数量
String criteriaKey = "guid"; // 过滤的条件
String criteriaValue = guid; // 过滤值
Criteria criteria = Criteria.where(criteriaKey).is(criteriaValue);
String collectionName = "test_mongodb"; // MongoDB中数据集合名称
GroupByResults<Map> mapGroupByResults = mongoTemplate.group(criteria, collectionName, groupBy, Map.class);
logger.info(mapGroupByResults.toString());
}
变量groupBy的属性值如下所示:

从上图中可以看出代码设置的值是有具体的含义的,可以明白这些值在group()函数中作用。
2、示例结果

从上图中我们可以看出分组结果已出来了,根据guid为"2"的条件下按性别进行分组:男的有2人,女的也有2人。而guid为"2"的记录总共有count=4.0,即4人。
需要注意的地方是,count=4.0的count属性是GroupByResult自带的,跟代码中设置的final String COUNT="count"没有关联的,在下面的测试结果中会发现这种差别。
  • 修改测试过程
1、代码稍作修改
public void test(String guid) {
String groupKey = "sex";
GroupBy groupBy = new GroupBy(groupKey);
final String COUNT = "total"; // 修改为total
DBObject initial = new BasicDBObject();
initial.put(COUNT, 0);
String reduce = "function (document, output) { "
+ " output." + COUNT + "++; "
+ "}";
// String finalize = "function (output) {"
// + "return output;"
// + "}";
groupBy = groupBy.reduceFunction(reduce);
groupBy = groupBy.collation(null);
// groupBy = groupBy.finalizeFunction(finalize);
groupBy = groupBy.finalizeFunction(null);
groupBy = groupBy.initialDocument(initial.toString());
String criteriaKey = "guid";
String criteriaValue = guid;
Criteria criteria = Criteria.where(criteriaKey).is(criteriaValue);
String collectionName = "test_mongodb";
GroupByResults<Map> mapGroupByResults = mongoTemplate.group(criteria, collectionName, groupBy, Map.class);
logger.info(mapGroupByResults.toString());
}
变量groupBy的属性值如下所示:

从上图中可以看到细微的差别是:initial的value值由"{"count":0}”变为"{"total":0}",这是因为在代码中修改了COUNT的赋值;此外,finalize也被赋值为null了,说明它对结果不会有影响。
2、测试结果

测试结果跟第一种的测试结果是类似的,只不过是通过关键字total来代表统计数量值了。

------20191209闪

Java对MongoDB进行分组操作并统计各个分组的数量的更多相关文章

  1. java学习(三) java 中 mongodb的各种操作

    一. 常用查询: 1. 查询一条数据:(多用于保存时判断db中是否已有当前数据,这里 is  精确匹配,模糊匹配 使用 regex...) public PageUrl getByUrl(String ...

  2. MySQL数据库Group by分组之后再统计数目Count(*)与不分组直接统计数目的区别

    简述问题“统计最新时刻处于某一状态的设备的数量” 1. 首先子查询结果,可以看到每个设备最新的状态信息 2.1 在子查询的基础上,对设备状态进行分组,进行统计每个状态的设备数量 2.1.1 可以看到处 ...

  3. mongodb在java驱动包下的操作(转)

    推荐几章很有用的文章 java操作参考文档 http://www.cnblogs.com/hoojo/archive/2011/06/02/2068665.html http://blog.csdn. ...

  4. java 对mongodb的操作

    java 对mongodb的操作 1.1连单台mongodb Mongo mg = newMongo();//默认连本机127.0.0.1  端口为27017 Mongo mg = newMongo( ...

  5. springboot 学习之路 14(整合mongodb的Api操作)

    springboot整合mongodb: mongodb的安装和权限配置  请点击连接参考 mongodb集成 : 第一步:引如pom文件 第二步:配置文件配置mongodb路径: 第三步:关于mon ...

  6. MongoDB的聚合操作以及与Python的交互

    上一篇主要介绍了MongoDB的基本操作,包括创建.插入.保存.更新和查询等,链接为MongoDB基本操作. 在本文中主要介绍MongoDB的聚合以及与Python的交互. MongoDB聚合 什么是 ...

  7. mongodb group php 操作

    紧接着上篇来,这篇主要讲,mongodb的group功能,做的还是挺强大的,相当对于find(),skip(),distinct()等,用法比较复杂. 测试数据 > db.fruit.find( ...

  8. MongoDB的基本使用及java对MongoDB的基本增删改查

    MongoDB的特点 MongoDB 是文档存储数据库,存储结构灵活 MongoDB 支持复杂查询操作.支持序列 MongoDB 采用C++开发,可以做分布式扩展 MongoDB 采用BSON格式存储 ...

  9. MongoDB第三天(正则,管道,聚合,字符串,算术,日期,java连接MongoDB)

    部分正则表达式: i:忽略大小写 m:多行查找 x:设置 x 选项后,正则表达式中的非转义的空白字符将被忽略.   s:允许点字符(即.)匹配包括换行符在内的所有字符. w:匹配包括下划线的任何单词字 ...

随机推荐

  1. 杭电-------2048不容易系列之(4)考新郎(C语言)

    /* 思路:有n位新郎,但是又m位新郎会找错,那么有n-m位新郎会找对,而找对的n-m位新郎的找发就是在 n位新郎中随机找n-m位有多少种排列组合公式有n!/(m!*(n-m!)),而另外找错的新郎则 ...

  2. webpack 中那些最易混淆的 5 个知识点

    学习博客:https://blog.csdn.net/wsyzxxn9/article/details/90677770 学习lodash:https://www.html.cn/doc/lodash ...

  3. 物理机安装ESXI6.7提示No Network Adapters的解决方案

    下载好ESXI6.7.iso镜像,写入U盘后,提示No Network Adapters,找不到网卡驱动. 解决办法:需要重新封装ESXI,将对应的网卡驱动嵌入进来. 1.先下载VMware-Powe ...

  4. css position absolute相对于父元素的设置方式

    手机赚钱怎么赚,给大家推荐一个手机赚钱APP汇总平台:手指乐(http://www.szhile.com/),辛苦搬砖之余用闲余时间动动手指,就可以日赚数百元 大家知道css的position abs ...

  5. centos6.8 安装.net core2.1 sdk 或 .net core2.1 runtime

    前段时间看.net core 更更更新了,大家反应都挺好,想有机会也学习一下,正好这两天要写一个简单的服务在centos上面跑,于是决定放弃使用java,直接.net core走起来,事情进行的非常顺 ...

  6. ES6 - 基础学习(1): 开发环境搭建

    现在Chrome浏览器已经很好的支持ES6了,但有些低版本的浏览器或其他浏览器还是不支持ES6的语法,因此实际项目开发或上线过程中就需要把ES6的语法转变成ES5的语法.项目开发过程中 Webpack ...

  7. Cesium案例解析(四)——3DModels模型加载

    目录 1. 概述 2. 代码 3. 解析 4. 参考 1. 概述 Cesium自带的3D Models示例,展示了如何加载glTF格式三维模型数据.glTF是为WebGL量身定制的数据格式,在网络环境 ...

  8. 返回一个整数数组中最大子数组的和——java程序设计

    一.题目要求 1.输入一个整形数组,数组里有正数也有负数.2.数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和.3.求所有子数组的和的最大值.要求时间复杂度为O(n) 二.设计思想 解决 ...

  9. go单任务版爬虫

    go单任务版爬虫(爬取珍爱网) 爬虫总体算法 单任务版爬虫架构 任务 获取并打印所在城市第一页用户的详细信息 代码实现 /crawler/main.go package main import ( & ...

  10. GraphQL + React Apollo + React Hook 大型项目实战(32 个视频)

    GraphQL + React Apollo + React Hook 大型项目实战(32 个视频) GraphQL + React Apollo + React Hook 大型项目实战 #1 介绍「 ...