mongodb的高级操作(聚合框架)

group by 查询 不要用java驱动带的group by ,要用2.2版本后的aggregate聚合框架来搞,经过试验速度快一倍

参考

官网:http://docs.mongodb.org/manual/reference/sql-aggregation-comparison/
实例:http://www.yeetrack.com/?p=649

观看例子前,请先看上面对的2个参考文档,特别是官网的

例子

[java] view plaincopy

    1. // 首先利$match筛选出where条件
    2. BasicDBObject[] array = {
    3. new BasicDBObject("startTimeLong", new BasicDBObject("$gte",beginTime)),
    4. new BasicDBObject("startTimeLong", new BasicDBObject("$lt",endTime)) };
    5. BasicDBObject cond = new BasicDBObject();
    6. cond.put("$and", array);
    7. DBObject match = new BasicDBObject("$match", cond);
    8. // 利用$project拼装group需要的数据,包含optCode列、processTime列
    9. DBObject fields = new BasicDBObject("optCode", 1); // 接口
    10. fields.put("processTime", 1);// 耗时
    11. fields.put("provinceCode", 1);// 省份
    12. fields.put("channelSubCode", 1);// 渠道
    13. fields.put("platFormCode", 1);// 平台
    14. DBObject project = new BasicDBObject("$project", fields);
    15. // 利用$group进行分组
    16. DBObject _group = new BasicDBObject("provinceCode", "$provinceCode");
    17. _group.put("channelSubCode", "$channelSubCode");
    18. _group.put("platFormCode", "$platFormCode");
    19. _group.put("optCode", "$optCode");
    20. DBObject groupFields = new BasicDBObject("_id", _group);
    21. //总数
    22. groupFields.put("count", new BasicDBObject("$sum", 1));
    23. //求和
    24. groupFields.put("processTime_sum", new BasicDBObject("$sum","$processTime"));
    25. DBObject group = new BasicDBObject("$group", groupFields);
    26. AggregationOutput output = MongodbUtil.getLogInfoCollection().aggregate(match, project, group);
时间: 2024-10-12 02:28:36

mongodb的高级操作(聚合框架)的相关文章

mongodb数据库高级操作

1.创建索引 2.索引名称 3.其他索引 4.explain 5.操作索引 6.高级特性 7.固定集合 8.导入导出 9.上锁 10.添加用户 11.主从复制

MongoDB学习--高级查询 [聚合Group]

Group大约需要一下几个参数. key:用来分组文档的字段.和keyf两者必须有一个 keyf:可以接受一个javascript函数.用来动态的确定分组文档的字段.和key两者必须有一个 initial:reduce中使用变量的初始化 reduce:执行的reduce函数.函数需要返回值. cond:执行过滤的条件. finallize:在reduce执行完成,结果集返回之前对结果集最终执行的函数.可选的 测试数据 //测试的数据 db.stocks.insert({"day": &

聚合框架

Pipeline语法简介 MongoDB聚合就是把一系列特殊操作符作用于一个集合.一个操作符就是一个拥有单个属性的JavaScript对象,其属性即操作符名称,其值是一个可选对象: { $name: { /* options */ } } 支持的操作符命名有:$project, $match, $limit, $skip, $unwind, $group, and $sort,它们每个都有其各自的选项集.一系列操作符就称为管道(Pipeline): [{ $project: { /* optio

【MongoDB】MongoDB之聚合框架(一)

题记: 还有3天2014年结束了,这个月的计划除了总结Mongodb外其他计划都已经完成了.最近由于懒惰对于mongodb的研究暂停了好长时间.在最后的三天里,对于mongodb的研究做以总结和梳理: 一.基本概念 对于聚合框架,我在官方文档(http://docs.mongodb.org/manual/core/aggregation-introduction/)找到对它的介绍.翻译大概意思如下: 聚合是处理数据记录并且返回计算结果的操作.mongodb提供了一组强大针对数据集合进行检查和计算

【MongoDB学习笔记30】MongoDB的聚合框架

使用聚合框架可以对集合中的文档进行变换和组合.用多个构件创建一个管道(pipeline),用于对一连串的文档进行处理.这些构件包括: 筛选(filtering) 投射(projecting) 分组(grouping) 排序(sorting) 限制(limiting) 跳过(skipping) 在MongoDB中实际的集合框架,需要将这些操作传给aggregate函数,例如: (1)将文档的name字段投射出来 > db.post.aggregate({$project:{"name&quo

【转载】8天学通MongoDB——第三天 细说高级操作

今天跟大家分享一下mongodb中比较好玩的知识,主要包括:聚合,游标. 一: 聚合 常见的聚合操作跟sql server一样,有:count,distinct,group,mapReduce. <1> count count是最简单,最容易,也是最常用的聚合工具,它的使用跟我们C#里面的count使用简直一模一样. <2> distinct 这个操作相信大家也是非常熟悉的,指定了谁,谁就不能重复,直接上图. <3> group 在mongodb里面做group操作有点

MongoDB(4): 聚合框架

一.简介 MongoDB的聚合框架,主要用来对集合中的文档进行变换和组合,从而对数据进行分析以加以利用. 聚合框架的基本思路是: 采用多个构件来创建一个管道,用于对一连串的文档进行处理. 这些构件包括: 筛选(filtering).投影(projecting).分组(grouping).排序(sorting).限制(limiting)和跳过(skipping). 使用聚合框架的方式: db.集合.aggregate(构件1,构件2-) 注意:由于聚合的结果要返回到客户端,因此聚合结果必须限制在1

MongoDB 的聚集操作

聚合引言 聚集操作就是出来数据记录并返回计算结果的操作.MongoDB提供了丰富的聚集操作,能够检测和执行数据集上的计算.运行在mongod上的数据聚集简化了代码和资源限制. 像查询一样,在Mongo的聚合操作使用collections作为输入,并返回一个或多个document作为输出. 聚合模式 聚合管道 MongoDB2.2引入了一个新的聚合框架:聚合管道,这是基于数据处理管道概念的模型.文档输入一个多阶段的管道并将文档转化为一个聚合的结果. 最基本的管道阶段提供了过滤器(Filters)来

MongoDB的简单操作

一.简介 二.MongoDB基础知识 三.安装 四.基本数据类型 五.增删改查操作 六.可视化工具 七.pymongo 一.简介 MongoDB是一款强大.灵活.且易于扩展的通用型数据库 MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性能. MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案. MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成.MongoDB 文档