位置: 编程技术 - 正文

Mongodb中MapReduce实现数据聚合方法详解

编辑:rootadmin

推荐整理分享Mongodb中MapReduce实现数据聚合方法详解,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

Mongodb是针对大数据量环境下诞生的用于保存大数据量的非关系型数据库,针对大量的数据,如何进行统计操作至关重要,那么如何从Mongodb中统计一些数据呢?

在Mongodb中,给我们提供了三种用于数据聚合的方式:

(1)简单的用户聚合函数;

(2)使用aggregate进行统计;

(3)使用mapReduce进行统计;

今天我们首先来讲讲mapReduce是如何统计,在后续的文章中,将另起文章进行相关说明。

MapReduce是啥呢?以我的理解,其实就是对集合中的各个满足条件的文档进行预处理,整理出想要的数据然后进行统计得到最终的统计结果。其中map函数用于对集合中的各个满足条件的文档进行预处理,整理出想要的数据。Reduce函数用于对整理出的数据进行处理得到统计结果。Map函数和Reduce函数都是JavaScript函数。

首先,我们先构造一个测试数据集test,使用js脚本往集合中随机插入一组数据,每条记录是哪个人花了多少钱买了什么东西。具体脚本test1.js如下:

接下来我们通过在控制台执行脚本来向数据库插入具体的数据,具体执行指令如下:

执行之后,通过MongoVUE来查看下具体的数据,如下所示,数据已经插入到集合中了:

接下来,我们可以做几个简单的统计操作了。

(1)统计不同用户都买了多少个商品?编写js脚本test2.js,将结果保存到statis1集合中。

按照刚才执行脚本的方式执行test2.js,并查看数据:

从数据库就可以直观看到统计数据了,若想查看某个人如majing购买了多少个商品,直接使用

(2)统计每个用户购买的每个商品的数量情况

脚本test3.js如下所示:

Mongodb中MapReduce实现数据聚合方法详解

按照刚才执行脚本的方式执行test3.js,并查看数据:

总共返回了条记录。此时如果我们想查找某个用户购买商品的情况,可以使用下面的查询方法:

如果我们想查找某个用户购买某个商品的情况,可以使用下面的查询方法:

(3)统计每个用户购买商品的总量及花费的总金额

脚本test4.js如下所示:

按照刚才执行脚本的方式执行test4.js,并查看数据:

(4)统计每个用户购买商品的平均价钱

在这个情景下,我们需要用到说道mapReduce里的另一个参数finalize,该参数是一个javascript脚本函数,用于对reduce后的集合进行一个后期处理操作。

执行脚本test5.js,具体如下所示:

执行之后查看得到的数据,具体如下所示,显示了总价钱,商品数量和商品单价。

如果想查找某个人的,可以和上面的查询方法一样,使用find()方法进行查询:

以上通过4个简单的例子对Mongodb中的MapReduce进行了简单的说明,当然MapReduce功能很强大,大家如果想知道其他高级的使用方法,可以到Mongodb的官网进行查阅和学习,网址为

谢谢。

以上所述是小编给大家介绍的Mongodb中MapReduce实现数据聚合方法详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对积木网网站的支持!

MongoDB 学习笔记(一)-MongoDB配置 MongoDB简介MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。MongoDB是一个介于关系数据

MongoDB快速翻页的方法 翻阅数据是MongoDB最常见的操作之一。一个典型的场景是需要在你的用户界面中显示你的结果。如果你是批量处理的数据,同样重要的是要让你的分页策

MongoDB快速入门笔记(六)之MongoDB删除文档操作 MongoDB是一个跨平台,面向文档的数据库,提供高性能,高可用性和易于扩展。MongoDB是工作在集合和文档上一种概念。文档是一组键值对。文档具有动态

标签: Mongodb中MapReduce实现数据聚合方法详解

本文链接地址:https://www.jiuchutong.com/biancheng/312539.html 转载请保留说明!

上一篇:Mongodb聚合函数count、distinct、group如何实现数据聚合操作(mongodb聚合函数mapreduce)

下一篇:MongoDB 学习笔记(一)-MongoDB配置(mongodb 教程)

  • 个人所得税纳税记录
  • 小规模纳税人销售农产品税率是多少
  • 公司车辆过户给个人车牌可以保留吗
  • 企业所得税优惠政策最新2023小规模纳税人
  • 未确认融资费要还款吗
  • 应税项目和非应税项目起征点一样吗
  • 一年房租正常摊销多少
  • 预提的费用在做所得税的时候如何处理
  • 公司筹建期间可以多久
  • 财务软件续费怎么记账
  • 工资 小数点
  • 营改增试点纳税人提供有形动产租赁服务,税率为
  • 以前年度社保计提出错了怎么调整
  • 个人挂靠公司承接工程如何做会计处理?
  • 个人股东无偿借款给企业
  • 奖励费收入是什么
  • 报关单上的运费怎么看
  • 增值税电子发票没有发票专用章
  • 法院执行费怎么收取法律依据
  • 货代发票税率是多少
  • 免税进口种子要符合哪些条件?
  • 外资公司办事处职能
  • 企业投资的工程项目包括
  • win10启用网络发现保存后又变成了关闭
  • macOS Big Sur 11.2 开发者预览版 Beta如何更新?
  • 电脑开机显示屏显示无信号黑屏怎么办
  • 在一个js文件中怎么写
  • 行政事业性收费目录
  • 专票抵扣联可以盖两个章吗
  • 结转制造费用用什么科目
  • js解构赋值浏览器报错
  • 用php写个简单的编程
  • 四舍五入的弊端
  • 利润表没有本月金额只有本年累计可以吗
  • 企业增值税的税收优惠有哪些
  • 固定资产停止使用还要折旧吗
  • 工商年报股东实缴出资金额能写0吗
  • 特惠贷利息怎么算
  • 教育培训学校是什么意思
  • 自产和外购用于赠送
  • 个人提供劳务增值税专用发票
  • 待处理财产损益借方增加还是减少
  • 建筑行业会计做账流程及会计分录
  • 文化事业建设费会计分录
  • 报废车补贴政策2023
  • 农业种植补贴需要审批吗
  • 转让负债 增值税
  • 应付账款借方余额负数表示什么
  • 接受捐赠的固定资产进项税额可以抵扣吗
  • 跨年红字发票账务处理
  • 企业购买国债逆回购要交企业所得税吗
  • 什么是成品油发票
  • 小规模纳税人建筑服务预缴增值税
  • 平均增长率计算公式怎么算
  • 集团管理费收入是否纳税
  • 资本性支出项目管理
  • 固定资产清理账户借方的核算内容包括
  • mysql alter table修改表命令整理
  • 微软停止更新win7
  • 2021win10激活
  • win10系统怎么修改用户名称
  • win10安全系统
  • 从硬盘安装系统
  • mac双系统切换快捷键
  • 虚拟机安装win7一直卡在完成安装
  • win7笔记本设置合上盖子不休眠
  • win7的记事本在哪里打开
  • linux应用程序在哪个目录
  • perl-v
  • eclipse 单词
  • 如何设置div自适应宽度
  • 删除命令del
  • svn如何cleanup
  • unity3d碰撞体
  • unity ugu
  • js实现双击屏幕放大
  • js随机生成一个整数
  • 深圳地方税务局电话
  • 成都交通官网限号查询系统
  • 个税系统崩溃
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设