MongoDB的分组统计 group

https://www.cnblogs.com/zhangzxl/p/4079641.html

mongodb中的分组聚合用$group,而且处理的最大数据量为100M如果超出需要写入到磁盘,使用格式如下:

1

{ $group: { _id: <expression>, <field1>: { <accumulator1> : <expression1> }, ... } }

  其中_id属性是必须要有的,目的是用来指定分组的字段或依据,field1为自定义字段,accumulator为累加器,下面以统计每天用户注册数为列

1

2

3

4

5

6

7

8

9

10

11

12

db.user.aggregate([

    {

        $group:{

            _id:{

                year:{$year:{$add:["$time",28800000]}},//time为注册时间 $year表示获取年份,用add是因为mongodb存的是UTC时间需要增加8个小时

                month:{$month:{$add:["$time",28800000]}},//$month获取月份

                day:{$dayOfMonth:{$add:["$time",28800000]}}//$dayOfMonth获取多少号

            }

            count:{$sum:1}//$sum为累计,1表示累加数

        }

    }

])

  如果只想注册地区为四川的则在$goup前增加一个$match:

1

2

3

4

5

{

    $match:{

         location:"SiChuan"

    }

},

  以上两个聚合操作的java实现方式:

复制代码

DBObject filterCond = new BasicDBObject();
filterCond.put("location", "SiChuan");
DBObject match = new BasicDBObject("$match", filterCond);

BasicDBList dateList = new BasicDBList();
dateList.add("$time");
dateList.add(28800000);//解决timezone 8小时时差
DBObject time = new BasicDBObject("$add", dateList);
DBObject group = new BasicDBObject(); 
DBObject groupDate = new BasicDBObject(); 
groupDate.put("year", new BasicDBObject("$year", time)); 
groupDate.put("month", new BasicDBObject("$month", time)); 
groupDate.put("day", new BasicDBObject("$dayOfMonth", time)); 
group.put("$group", new BasicDBObject("_id", groupDate));
AggregationOutput output = coll.aggregate(match, group); 
Iterator iterator = output.results().iterator();

复制代码

  更多的聚合操作请参见这》》》http://docs.mongodb.org/manual/reference/operator/aggregation-pipeline/

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值