mongdb高级操作(group by )

2023-11-05 06:58
文章标签 操作 高级 group mongdb

本文主要是介绍mongdb高级操作(group by ),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先介绍哈方法

/** * 利用java驱动自带函数分组查询 *

@param key 用来分组文档的字段 【group by key】 *

@param cond 执行过滤的条件 【where name=? and age=?】 *

@param initial reduce中使用变量的初始化 * @param reduce reduce(参数:当前文档和累加器文档.) *

@param fn 结束后执行函数 *

@return */

 

参考例子1:

group(DBObject key,DBObject cond,DBObject initial,String reduce,String fn ){

             //key:用来分组文档的字段。和keyf两者必须有一个 [类似于group by]

             BasicDBObject key = new BasicDBObject(); key.put("optCode", true);

             //执行过滤的条件 [类似于where]

             BasicDBObject[] array={ new BasicDBObject("startTimeLong",

             new BasicDBObject("$gte", startTime)),

             new BasicDBObject("startTimeLong", new BasicDBObject("$lte", endTime)) };

             BasicDBObject cond = new BasicDBObject(); //cond.put("$and",array);

             //initial:reduce中使用变量的初始化

             BasicDBObject initial = new BasicDBObject();

             initial.append("count", 0);

             //reduce(当前文档和累加器文档.)

             String reduce = "function(doc, aggr){" + " aggr.count += 1;" + " }";

             String fn = null;            

             dao.group(key, cond, initial, reduce, fn);

 }

 

参考例子2:

 //求总数和平局数

public Double findAverage(String sumField, String groupField, BasicDBObject where)

 {

          // 分组项字段 【group by groupField】

          DBObject key = new BasicDBObject(groupField, null)

         // 结果数据计数器 【select avg,rsdata.sum,rsdata.count 】

          BasicDBObject counter = new BasicDBObject();

         DBObject index = new BasicDBObject();

         index.put("count", 0);

         index.put("sum", 0);

         counter.put("rsdata", index);counter.put("avg", 0);}

         // reduce处理函数

         String procFunction = "function(doc,aggr){" + "aggr.rsdata.sum+=parseFloat(doc." + sumField + ");" + "aggr.rsdata.count+=1;" + "}";

         // 结果处理函数

         String finallyFunction = "function(doc){" + "doc.avg=doc.rsdata.sum/doc.rsdata.count;" + "}";

         BasicDBList rs = (BasicDBList) getCollection().group(key, where, counter, procFunction, finallyFunction);

         if (null != rs && rs.size() > 0)

         {BasicDBObject data = (BasicDBObject) rs.get(0);

         return Double.parseDouble(data.get("avg").toString());} return 0.0;

}

这篇关于mongdb高级操作(group by )的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/348187

相关文章

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

SpringBoot操作spark处理hdfs文件的操作方法

《SpringBoot操作spark处理hdfs文件的操作方法》本文介绍了如何使用SpringBoot操作Spark处理HDFS文件,包括导入依赖、配置Spark信息、编写Controller和Ser... 目录SpringBoot操作spark处理hdfs文件1、导入依赖2、配置spark信息3、cont

使用JavaScript操作本地存储

《使用JavaScript操作本地存储》这篇文章主要为大家详细介绍了JavaScript中操作本地存储的相关知识,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录本地存储:localStorage 和 sessionStorage基本使用方法1. localStorage

使用JavaScript将PDF页面中的标注扁平化的操作指南

《使用JavaScript将PDF页面中的标注扁平化的操作指南》扁平化(flatten)操作可以将标注作为矢量图形包含在PDF页面的内容中,使其不可编辑,DynamsoftDocumentViewer... 目录使用Dynamsoft Document Viewer打开一个PDF文件并启用标注添加功能扁平化

JavaScript DOM操作与事件处理方法

《JavaScriptDOM操作与事件处理方法》本文通过一系列代码片段,详细介绍了如何使用JavaScript进行DOM操作、事件处理、属性操作、内容操作、尺寸和位置获取,以及实现简单的动画效果,涵... 目录前言1. 类名操作代码片段代码解析2. 属性操作代码片段代码解析3. 内容操作代码片段代码解析4.

SpringBoot使用Apache POI库读取Excel文件的操作详解

《SpringBoot使用ApachePOI库读取Excel文件的操作详解》在日常开发中,我们经常需要处理Excel文件中的数据,无论是从数据库导入数据、处理数据报表,还是批量生成数据,都可能会遇到... 目录项目背景依赖导入读取Excel模板的实现代码实现代码解析ExcelDemoInfoDTO 数据传输

Python使用asyncio实现异步操作的示例

《Python使用asyncio实现异步操作的示例》本文主要介绍了Python使用asyncio实现异步操作的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录1. 基础概念2. 实现异步 I/O 的步骤2.1 定义异步函数2.2 使用 await 等待异

Python中列表的高级索引技巧分享

《Python中列表的高级索引技巧分享》列表是Python中最常用的数据结构之一,它允许你存储多个元素,并且可以通过索引来访问这些元素,本文将带你深入了解Python列表的高级索引技巧,希望对... 目录1.基本索引2.切片3.负数索引切片4.步长5.多维列表6.列表解析7.切片赋值8.删除元素9.反转列表

正则表达式高级应用与性能优化记录

《正则表达式高级应用与性能优化记录》本文介绍了正则表达式的高级应用和性能优化技巧,包括文本拆分、合并、XML/HTML解析、数据分析、以及性能优化方法,通过这些技巧,可以更高效地利用正则表达式进行复杂... 目录第6章:正则表达式的高级应用6.1 模式匹配与文本处理6.1.1 文本拆分6.1.2 文本合并6

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核