分组统计:group()

简单聚合:aggregate()
强大统计:mapReduce()

Group函数:

1.不支持集群、分片,无法分布式计算

2.需要手写聚合函数的业务逻辑


curr指当前行,每更改一行,curr会变

result指的是当前组,每更改一组,result会变,返回的就是result的参数

查询每个栏目下的商品数量
1
2
3
4
5
6
7
8
db.goods.group({
key:{cat_id:1},
cond:{},
reduce:function(curr,result){
     result.cnt +=1;
},
initial:{cnt:0}
});

查找每个栏目下商品价格大于50的商品数量

1
2
3
4
5
6
7
8
db.goods.group({
key:{cat_id:1},
cond:{shop_price:{$gt:50}},
initial:{cnt:0},
reduce:function(curr,result){
     result.cnt +=1;
}
});

每个栏目下的商品库存量sum操作

1
2
3
4
5
6
7
8
db.goods.group({
key:{cat_id:1},
cond:{},
initial:{cnt:0},
reduce:function(curr,result){
     result.num += curr.goods_number;
}
});

计算每个栏目下最贵的商品,实现max()函数

1
2
3
4
5
6
7
8
9
10
db.goods.group({
key:{cat_id:1},
cond:{},
initial:{max:0},
reduce:function(curr,result){
     if(curr.shop_price > result.max ){
          result.max = curr.shop_price;    
     }
}
});

计算每个栏目下商品 的平均价格cu

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
db.goods.group({
key:{cat_id:1},
cond:{},
initial:{cnt:0,sum:0},
reduce:function(curr,result){
     if(curr.shop_price > result.max ){
           result.cnt += 1;
           result.sum += curr.shop_price;
     }
},
  
finalize:function(result){
     result.avg = result.sum / result.avg;
}
});

aggregate()函数

where $match
group by  $group
having $match
select $project
order by  $sort
limit $limit
sum() $sum
count() $sum

查询每个栏目下的商品数量

1
2
3
db.collection.aggreagte([
{$group:{_id:"$cat_id",total:{$sum:1}}}
]);

查询goods下有多少商品

1
2
3
db.collection.aggreagte([
{$group:{_id:null,total:{$sum:1}}}
]);

查询每个栏目下价格大于50的商品,并筛选出“满足条件的商品数量大于等于3”的栏目

match在group前是SQL中match的作用,match在group后是having的作用

1
2
3
4
5
db.collection.aggreagte([
{$match:{shop_price:{$gt:50}}},
{$group:{_id:null,total:{$sum:1}}},
{$match:{total:{$gte:3}}},
]);

查询每个栏目下的库存量,并按照库存量排序

1
2
3
4
db.collection.aggreagte([
{$group:{_id:"$cat_id",total:{$sum:"$goods_number"}}},

{$sort:{total:1}}}, // 这个1表示正序排列,-1表示倒序排列

{$limit:4}   // 只取前四个

]);

查询每个栏目的商品平均价格,并按照平均价格由高到低排序

--这个group有不少参数,官方文档里面有

1
2
3
4
db.collection.aggreagte([
{$group:{_id:"$cat_id",avg:{$avg:"$shop_price"}}}, //$符号是转为列的意思
{$sort:{avg:1}}}
]);

MapReduce

mapReduce随着大数据的概念而流行

其实mapReduce的概念非常简单

从功能上来说,相当于RDMS的group操作

它的真正强项在于分布式,当数据非常大时,分布在各个地方时,group就力不能及了,mapReduce用蛮力来计算,mapReduce工作过程

map-->映射,先把同一个组的数据,映射到一个数组上

reduce-->规约,把数组进行运算

简单用法

1
2
3
4
5
var map = function(){
        emit(this.cat_id,this.shop_price);
}
var reduce = function(cat_id,all_price){XX各种数据操作};
db.goods.mapReduce(map,reduce,{quer:{},out:'res'});  //把查询到的结果输出为res表

mongodb对js的引擎做了一些修改对array数组增加了一些函数

mapReduce一般写在mongos上

数据库-mongodb-聚合与map reduce的更多相关文章

  1. 数据库——MongoDB——>Java篇

         MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案.      MongoDB  是一个介于关系数据库和非关系数据库之间的产 ...

  2. 非关系型数据库----MongoDB

    一.什么是MongoDB? MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性能. MongoDB 旨在为WEB应用提 ...

  3. python数据库-MongoDB的安装(53)

    一.NoSQL介绍 1.什么是NoSQL NoSQL(NoSQL = Not Only SQL ),意即"不仅仅是SQL". NoSQL,指的是非关系型的数据库.NoSQL有时也称 ...

  4. MongoDB Map Reduce(转载)

    MongoDB Map Reduce Map-Reduce是一种计算模型,简单的说就是将大批量的工作(数据)分解(MAP)执行,然后再将结果合并成最终结果(REDUCE). MongoDB提供的Map ...

  5. 记一次MongoDB Map&Reduce入门操作

    需求说明 用Map&Reduce计算几个班级中,每个班级10岁和20岁之间学生的数量: 需求分析 学生表的字段: db.students.insert({classid:1, age:14, ...

  6. mongodb Map/reduce测试代码

    private void AccountInfo() { ls.Clear(); DateTime dt = DateTime.Now.Date; IMongoQuery query = Query& ...

  7. Mongodb学习笔记四(Mongodb聚合函数)

    第四章 Mongodb聚合函数 插入 测试数据 ;j<;j++){ for(var i=1;i<3;i++){ var person={ Name:"jack"+i, ...

  8. MongoDB 聚合 (转) 仅限于C++开发

    MongoDB除了基本的查询功能,还提供了很多强大的聚合工具,其中简单的可计算集合中的文档个数, 复杂的可利用MapReduce做复杂数据分析. 1.count count返回集合中的文档数量 db. ...

  9. Mongodb聚合函数

    插入 测试数据 for(var j=1;j<3;j++){ for(var i=1;i<3;i++){ var person={ Name:"jack"+i, Age: ...

随机推荐

  1. 【CareerCup】Trees and Graphs—Q4.3

    转载请注明出处:http://blog.csdn.net/ns_code/article/details/24744177     题目: Given a sorted (increasing ord ...

  2. spark中的广播变量broadcast

    Spark中的Broadcast处理 首先先来看一看broadcast的使用代码: val values = List[Int](1,2,3) val broadcastValues = sparkC ...

  3. 【Dubbo实战】基础学习篇(一)

    Dubbo的简单介绍 是什么? Dubbo是阿里巴巴SOA服务化治理方案的核心框架,每天为2,000多个服务提供30多亿次訪问量支持.并被广泛应用于阿里巴巴集团的各成员网站. Dubbo是一个分布式服 ...

  4. windows命令行方式下打印和设置PATH变量

    点击开始菜单,运行=>cmd打印当前变量:echo %PATH%结果:C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\System32\Wbem;d:\PRO ...

  5. 写函数,输入n个数字输出最大值和最小值

    # ,写函数,传入n个数,返回字典{‘max’:最大值,’min’:最小值}# 例如:min_max(2,5,7,8,4) 返回:{‘max’:8,’min’:2}(此题用到max(),min()内置 ...

  6. nginx令牌限制并发

    http{ limit_req_zone $binary_remote_addr zone=req_one:10m rate=100r/s; server { listen 8080; server_ ...

  7. Linux下编译安装Memcache

    需要gcc,make,cmake,autoconf,libtool等工具,联网后,yum install -y gcc,make,cmake,autoconf,libtool 编译安装libevent ...

  8. js闭包概念

    含义:闭包是一个概念,它描述了函数执行完毕内存释放后,依然内存驻留的一个现象,只要把握这个核心概念,闭包就不难理解了 function a(){      var i=0;      function ...

  9. 详解循环神经网络(Recurrent Neural Network)

    本文结构: 模型 训练算法 基于 RNN 的语言模型例子 代码实现 1. 模型 和全连接网络的区别 更细致到向量级的连接图 为什么循环神经网络可以往前看任意多个输入值 循环神经网络种类繁多,今天只看最 ...

  10. SQL Server-聚焦移除Bookmark Lookup、RID Lookup、Key Lookup提高SQL查询性能

      前言 前面几节都是讲的基础内容,本节我们讲讲索引性能优化,当对大数据进行处理时首先想到的就是索引,一旦遇到这样的问题则手忙脚乱,各种查资料,为何平常不扎实基本功呢,我们由浅入深,简短的内容,深入的 ...