标签:logs 客户端 字段名 聚合 类型转换 com 分组 bsp 计算
使用聚合,db.集合名.aggregate… 而不是find
管道在Unix和Linux中一般用于将当前命令的输出结果作为下一个命令的参数。
MongoDB的聚合管道将MongoDB文档在一个管道处理完毕后将结果传递给下一个管道处理。管道操作是可以重复的。
每一个操作符(集合)都会接受一连串的文档,对这些文档做一些类型转换,最后将转换后的文档作为结果传递给下一个操作符,对于最后一个操作符,是将结果返回给客户端
//分组(这里制定了分组字段 $+字段名)
//这里可以理解为,吧lastModifyByUserCode 当作唯一标识 _id,字段count 用 $sum 计算 同一个lastModifyByUserCode出现次数
db.test.aggregate({‘$group‘:{‘_id‘:‘$lastModifyByUserCode‘,‘count‘:{‘$sum‘:1}}})
//显示其他字段(必须使用聚合[$sum,$avg,$first,$last,$max,$min,$push,$addToSet,$stdDevPop,$stdDevSamp])
db.test.aggregate({‘$group‘:{‘_id‘:‘$lastModifyByUserCode‘,‘count‘:{‘$sum‘:1},‘createTime‘:{‘$first‘:"$createTime"}}})
$match 用于对文档集合进行筛选,支持find一样的筛选条件,不能在$match中使用地理空间操作符,(尽量把$match放在多个聚合中的第一个,这样可以有效利用索引)
而且根据官方文档,如果在$match使用了全文索引,后面跟着的聚合就不用再使用$text
标签:logs 客户端 字段名 聚合 类型转换 com 分组 bsp 计算
原文地址:http://www.cnblogs.com/sweetchildomine/p/6430368.html