设为首页 加入收藏

TOP

MongoDB:详细解释mongodb的高级操作,聚合和游标
2014-11-23 21:29:58 来源: 作者: 【 】 浏览:19
Tags:MongoDB 详细 解释 mongodb 高级 操作 聚合 游标

前几天总结了mongodb的安装入门、详细解释了增删改查的基本操作,今天再来总结下mongodb更高级的操作,聚合和游标。

一、聚合,mongodb的聚合操作一般分为四种情景,分别是:count、distinct、group、mapReduce

1、count

count最简单,最容易,也是我们最常用的聚合工具,话说最常用的大家都会用,所以对大家都不是问题,所以叫最简单~~奋斗

count
db.person.find()
db.person.count()
db.person.count({"age":40})
\

2、distinct< http://www.2cto.com/kf/ware/vc/" target="_blank" class="keylink">vcD4KPHA+ucvD+8u80uWjrNa4tqjBy8uto6zLrb7NsrvE3NbYus+hozwvcD4KPHA+PHByZSBjbGFzcz0="brush:sql;">db.person.distinct("age")
\

3、group

group的操作有些小复杂,但是越是复杂的操作,应用起来就越灵活,group的操作本质上相当于一种“key-value”模型。

下面举的例子就是按照age进行group操作,value为对应age的姓名。下面对这些参数介绍一下:

key: 这个就是分组的key,我们这里是对年龄分组。
initial: 每组都分享一个”初始化函数“,特别注意:是每一组,比如这个的age=10的value的list分享一个initial函数,age=40同样也分享一个initial函数。
$reduce: 这个函数的第一个参数是当前的文档对象,第二个参数是上一次function操作的累计对象,第一次为initial中的{”perosn“:[]}。有多少个文档, $reduce就会调用多少次。

group

db.person.group({
	"key":{"age":true},
	"initial":{"person":[]},
	"$reduce":function(cur,prev){
	  	prev.person.push(cur.name);
}
})

\

上面的结果,有时候我们还可能会有其他的需求,例如:

1、过滤掉age<26岁的成员。

2、有时候person的成员太多,我不可能一一查看,所以我想count一下,这样看起来也比较方便。

这在group是非常容易办到的,因为mongodb有两个可选参数:condition 和finalize

condition 是个过滤条件

finalize 是一个方法,每个文章执行完后,都会触发它,可以在这个方法里面加入count。

condition 和 finalize
db.person.group({
	"key":{"age":true},
	"initial":{"person":[]},
	"$reduce":function(cur,prev){
	  	prev.person.push(cur.name);
	},
	"finalize":function(count){
		out.count=out.person.length;
	},
	"condition":{"age":{$gte:10}}
})
\

4、mapReduce

mapReduce其实是一种编程模型,用在分布式计算中,其中有一个“map”函数,一个”reduce“函数。
1、map:
这个称为映射函数,里面会调用emit(key,value),集合会按照你指定的key进行映射分组。
2、reduce:
这个称为简化函数,会对map分组后的数据进行分组简化,注意:在reduce(key,value)中的key就是
emit中的key,vlaue为emit分组后的emit(value)的集合,这里也就是很多{"count":1}的数组。
3、mapReduce:
这个就是最后执行的函数了,参数为map,reduce和一些可选参数。具体看图可知:

mapReduce

map
function(){
	emit(this.name,{count:1});
}

reduce
function(key,value){
	var result={count:0};
	for(var i=0;i
 seo8L3A+CjxwPiBtb25nb2RiwO/D5rXE086x6tPQtePA4CYjMjAyODQ7ztLDx8u1tcRDI8Dvw+bR07PZ1rTQ0KOsscjI56O6PGJyPgogICAgICB2YXIgbGlzdD1kYi5wZXJzb24uZmluZCgpOzxicj4KICAgINXrttTV4tH5tcSy2df3o6xsaXN0xuTKtbKiw7vT0LvxyKG1vXBlcnNvbtbQtcTOxLW1o6y2+MrHyerD99K7uPahsLLp0a+94bm5obGjrLXIztLDx9Do0qq1xMqxuvLNqLn9CmZvcrvy1d9uZXh0KCnSu7TO0NS809TYuf3AtKOsyLu688jD086x6tbw0NC2wciho6y1sc7Sw8fDtr7ZzerBy9auuvOjrNPOserP+rvZo6zWrrrzztLDx9Tazai5/Wxpc3S78cihyrGjrLeiz9bDu9PQyv2+3be1u9jBy6GjPGJyPgo8L3A+CjxwPjxwcmUgY2xhc3M9"brush:sql;">游标 var list = db.person.find(); list.forEach(function(x){ print(x.name); })
 \
 

同时,我们也可以查用分页、排序等查询!

这样可以减少不必要的开销

var single=db.person.find().sort({"name":1}).skip(2).limit(2);


好啦,聚合和游标基本就这些,如果有不对的地方敬请指正。

原创文章,转载请注明出处:http://blog.csdn.net/jessonlv

下期会写关于mongodb索引的建立等操作

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇DB2重定向恢复和前滚常见问题解析 下一篇DB2问题

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: