MongoDB虽然不像我们常用的mysql,sqlserver,oracle等关系型数据库有group by函数那样方便分组,但是MongoDB要实现分组也有3个办法:
* Mongodb三种分组方式:
* 1、group(先筛选再分组,不支持分片,对数据量有所限制,效率不高)
* 2、mapreduce(基于js引擎,单线程执行,效率较低,适合用做后台统计等)
* 3、aggregate(推荐) (如果你的PHP的mongodb驱动版本需>=1.3.0,推荐你使用aggregate,性能要高很多,并且使用上要简单些,不过1.3的目前还不支持账户认证模式,可以通过http://pecl.php.net/package/mongo查看更新日志和Bug)
下面就来看下mapreduce方式:
Mongodb官网对MapReduce介绍:
Map/reduce in MongoDB is useful for batch processing of data and aggregation operations. It is similar in spirit to using something like Hadoop with all input coming from a collection and output going to a collection. Often, in a situation where you would have used GROUP BY in SQL, map/reduce is the right tool in MongoDB.
- db.runCommand(
- { mapreduce : <collection>,
- map : <mapfunction>,
- reduce : <reducefunction>
- [, query : <query filter object>]
- [, sort : <sort the query. useful for optimization>]
- [, limit : <number of objects to return from collection>]
- [, out : <output-collection name>]
- [, keeptemp: <true|false>]
- [, finalize : <finalizefunction>]
- [, scope : <object where fields go into javascript global scope >]
- [, verbose : true]
- }
- );
参数说明:
mapreduce:要操作的目标集合
map:映射函数(生成键值对序列,作为Reduce函数的参数)
reduce:统计函数
query:目标记录过滤
sort:对目标记录排序
limit:限制目标记录数量
out:统计结果存放集合(如果不指定则使用临时集合,在客户端断开后自动删除)
keeptemp:是否保留临时集合
finalize:最终处理函数(对reduce返回结果执行最终整理后存入结果集合)
scope:向map、reduce、finalize导入外部变量
verbose:显示详细的时间统计信息
map函数调用当前对象,并处里对象的属性,传值给reduce,map方法使用this来操作当前对象,最少调用一次emit(key,value)方法来向reduce提供参数,其中emit的key为最终数据的id。
接收一个值和数组,根据需要对数组进行合并分组等处理,reduce的key就是emit(key,value)的key,value_array是同个key对应的多个value数组。
此函数为可选函数,可在执行完map和reduce后执行,对最后的数据进行统一处理。
- {
- "_id": ObjectId("50ccb3f91e937e2927000004"),
- "feed_type": 1,
- "to_user": 234,
- "time_line": "2012-12-16 01:26:00"
- }
- {
- "_id": ObjectId("50ccb3ef1e937e0727000004"),
- "feed_type": 8,
- "to_user": 123,
- "time_line": "2012-12-16 01:26:00"
- }
- {
- "_id": ObjectId("50ccb3e31e937e0a27000003"),
- "feed_type": 1,
- "to_user": 123,
- "time_line": "2012-12-16 01:26:00"
- }
- {
- "_id": ObjectId("50ccb3d31e937e0927000001"),
- "feed_type": 1,
- "to_user": 123,
- "time_line": "2012-12-16 01:26:00"
- }
我们按动态类型feed_type和用户to_user进行分组统计,实现结果:
feed_type | to_user | cout |
1 | 234 | 1 |
8 | 123 | 1 |
1 | 123 | 2 |
- //编写map函数
- $map = '
- function() {
- var key = {to_user:this.to_user,feed_type:this.feed_type};
- var value = {count:1};
- emit(key,value);
- } ';
- //reduce 函数
- $reduce = '
- function(key, values) {
- var ret = {count:0};
- for(var i in values) {
- ret.count += 1;
- }
- return ret;
- }';
- //查询条件
- $query = null; //本实例中没有查询条件,设置为null
- $mongo = new Mongo('mongodb://root:root@127.0.0.1: 28017/'); //链接mongodb,账号和密码为root,root
- $instance = $mongo->selectDB("testdb");
- //执行此命令后,会创建feed_temp_res的临时集合,并将统计后的数据放在该集合中
- $cmd = $instance->command(array(
- 'mapreduce' => 'feed',
- 'map' => $map,
- 'reduce' => $reduce,
- 'query' => $query,
- 'out' => 'feed_temp_res'
- ));
- //查询临时集合中的统计数据,验证统计结果是否和预期结果一致
- $cursor = $instance->selectCollection('feed_temp_res')->find();
- $result = array();
- try {
- while ($cursor->hasNext())
- {
- $result[] = $cursor->getNext();
- }
- }
- catch (MongoConnectionException $e)
- {
- echo $e->getMessage();
- }
- catch (MongoCursorTimeoutException $e)
- {
- echo $e->getMessage();
- }
- catch(Exception $e){
- echo $e->getMessage();
- }
- //test
- var_dump($result);
下面是输出的结果,和预期结果一致
- {
- "_id": {
- "to_user": 234,
- "feed_type": 1
- },
- "value": {
- "count": 1
- }
- }
- {
- "_id": {
- "to_user": 123,
- "feed_type": 8
- },
- "value": {
- "count": 1
- }
- }
- {
- "_id": {
- "to_user": 123,
- "feed_type": 1
- },
- "value": {
- "count": 2
- }
- }
- /**
- * mapReduce分组
- *
- * @param string $table_name 表名(要操作的目标集合名)
- * @param string $map 映射函数(生成键值对序列,作为 reduce 函数参数)
- * @param string $reduce 统计处理函数
- * @param array $query 过滤条件 如:array('uid'=>123)
- * @param array $sort 排序
- * @param number $limit 限制的目标记录数
- * @param string $out 统计结果存放集合 (不指定则使用tmp_mr_res_$table_name, 1.8以上版本需指定)
- * @param bool $keeptemp 是否保留临时集合
- * @param string $finalize 最终处理函数 (对reduce返回结果进行最终整理后存入结果集合)
- * @param string $scope 向 map、reduce、finalize 导入外部js变量
- * @param bool $jsMode 是否减少执行过程中BSON和JS的转换,默认true(注:false时 BSON-->JS-->map-->BSON-->JS-->reduce-->BSON,可处理非常大的mapreduce,//true时BSON-->js-->map-->reduce-->BSON)
- * @param bool $verbose 是否产生更加详细的服务器日志
- * @param bool $returnresult 是否返回新的结果集
- * @param array &$cmdresult 返回mp命令执行结果 array("errmsg"=>"","code"=>13606,"ok"=>0) ok=1表示执行命令成功
- * @return
- */
- function mapReduce($table_name,$map,$reduce,$query=null,$sort=null,$limit=0,$out='',$keeptemp=true,$finalize=null,$scope=null,$jsMode=true,$verbose=true,$returnresult=true,&$cmdresult){
- if(empty($table_name) || empty($map) || empty($reduce)){
- return null;
- }
- $map = new MongoCode($map);
- $reduce = new MongoCode($reduce);
- if(empty($out)){
- $out = 'tmp_mr_res_'.$table_name;
- }
- $cmd = array(
- 'mapreduce' => $table_name,
- 'map' => $map,
- 'reduce' => $reduce,
- 'out' =>$out
- );
- if(!empty($query) && is_array($query)){
- array_push($cmd, array('query'=>$query));
- }
- if(!empty($sort) && is_array($sort)){
- array_push($cmd, array('sort'=>$query));
- }
- if(!empty($limit) && is_int($limit) && $limit>0){
- array_push($cmd, array('limit'=>$limit));
- }
- if(!empty($keeptemp) && is_bool($keeptemp)){
- array_push($cmd, array('keeptemp'=>$keeptemp));
- }
- if(!empty($finalize)){
- $finalize = new Mongocode($finalize);
- array_push($cmd, array('finalize'=>$finalize));
- }
- if(!empty($scope)){
- array_push($cmd, array('scope'=>$scope));
- }
- if(!empty($jsMode) && is_bool($jsMode)){
- array_push($cmd, array('jsMode'=>$jsMode));
- }
- if(!empty($verbose) && is_bool($verbose)){
- array_push($cmd, array('verbose'=>$verbose));
- }
- $dbname = $this->curr_db_name;
- $cmdresult = $this->mongo->$dbname->command($cmd);
- if($returnresult){
- if($cmdresult && $cmdresult['ok']==1){
- $result = $this->find($out, array());
- }
- }
- if($keeptemp==false){
- //删除集合
- $this->mongo->$dbname->dropCollection($out);
- }
- return $result;
- }
相关推荐
综上所述,本篇文章从MongoDB的简介、安装、PHP扩展安装、PHP代码示例以及CRUD操作等方面对PHP与MongoDB的应用进行了介绍。用户通过上述步骤可以快速地将MongoDB嵌入到PHP应用中,并进行基本的数据库操作。随着应用...
在使用MapReduce时,需要注意的是,不同版本的MongoDB和PHP驱动可能存在差异,因此在不同环境下,代码的适用性和结果可能会有所不同。例如,上述示例是在MongoDB 1.6.5和PECL Mongo 1.1.4版本下编写的,其他版本可能...
资源内项目源码是来自个人的毕业设计,代码都测试ok,包含源码、数据集、可视化页面和部署说明,可产生核心指标曲线图、混淆矩阵、F1分数曲线、精确率-召回率曲线、验证集预测结果、标签分布图。都是运行成功后才上传资源,毕设答辩评审绝对信服的保底85分以上,放心下载使用,拿来就能用。包含源码、数据集、可视化页面和部署说明一站式服务,拿来就能用的绝对好资源!!! 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、大作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.txt文件,仅供学习参考, 切勿用于商业用途。
《基于YOLOv8的智慧社区独居老人生命体征监测系统》(包含源码、可视化界面、完整数据集、部署教程)简单部署即可运行。功能完善、操作简单,适合毕设或课程设计
Android Studio Meerkat 2024.3.1 Patch 1(android-studio-2024.3.1.14-mac.dmg)适用于macOS Intel系统,文件使用360压缩软件分割成两个压缩包,必须一起下载使用: part1: https://download.csdn.net/download/weixin_43800734/90557060 part2: https://download.csdn.net/download/weixin_43800734/90557056
侧轴承杯加工工艺编制及夹具设计.zip
NASA数据集锂电池容量特征提取(Matlab完整源码和数据) 作者介绍:机器学习之心,博客专家认证,机器学习领域创作者,2023博客之星TOP50,主做机器学习和深度学习时序、回归、分类、聚类和降维等程序设计和案例分析,文章底部有博主联系方式。从事Matlab、Python算法仿真工作8年,更多仿真源码、数据集定制私信。
板料折弯机液压系统设计.zip
C6150车床的设计.zip
机器学习之KNN实现手写数字
python爬虫;智能切换策略,反爬检测机制
mpls-vpn-optionA-all
56tgyhujikolp[
GB 6442-86企业职工伤亡事故调查分析规则.pdf
汽车液压式主动悬架系统的设计().zip
2000-2024年各省专利侵权案件结案数数据 1、时间:2000-2024年 2、来源:国家知识产权J 3、指标:专利侵权案件结案数 4、范围:31省 5、用途:可用于衡量知识产权保护水平
资源内项目源码是来自个人的毕业设计,代码都测试ok,包含源码、数据集、可视化页面和部署说明,可产生核心指标曲线图、混淆矩阵、F1分数曲线、精确率-召回率曲线、验证集预测结果、标签分布图。都是运行成功后才上传资源,毕设答辩评审绝对信服的保底85分以上,放心下载使用,拿来就能用。包含源码、数据集、可视化页面和部署说明一站式服务,拿来就能用的绝对好资源!!! 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、大作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.txt文件,仅供学习参考, 切勿用于商业用途。
内容概要:本文档详细复现了金融数学课程作业,涵盖欧式看涨期权定价和投资组合优化两大部分。对于欧式看涨期权定价,分别采用Black-Scholes模型和蒙特卡洛方法进行了计算,并对彩虹期权进行了基于最大值的看涨期权定价。投资组合优化部分则探讨了最小方差组合、给定收益的最小方差组合、最大效用组合以及给定风险的最大收益组合四种情形,还对比了拉格朗日乘数法和二次规划求解器两种方法。文中不仅提供了详细的MATLAB代码,还有详尽的中文解释,确保每一步骤清晰明了。 适合人群:金融工程专业学生、量化分析师、金融数学爱好者。 使用场景及目标:①帮助学生理解和掌握金融衍生品定价的基本原理和方法;②为从事量化分析的专业人士提供实用工具和技术支持;③作为教学材料辅助高校教师讲授相关内容。 其他说明:文档还包括了完整的论文结构建议,从封面页到结论,再到附录,涵盖了所有必要元素,确保提交的作业符合学术规范。此外,还特别强调了数据预处理步骤,确保代码可以顺利运行。
脉冲电解射流加工喷射装置设计(1)
ThinkPad S1 (2nd Generation) 和ThinkPad Yoga 260 用户指南V3.0,包含如何拆机更换硬件