位置: 编程技术 - 正文

MongoDB中MapReduce编程模型使用实例

编辑:rootadmin

注:作者使用的MongoDB为2.4.7版本。单词计数示例:

插入用于单词计数的数据:

图个简洁,数据中没有包含标点符号。 在mongo shell写入以下内容:

db.data.mapReduce的第一和第二个参数分别指定map和reduce,map的输入是集合中的每个文档,通过emit()生成键值对;而reduce则处理键的多个值。

mapReduce的第三个参数指明在内存中进行mapreduce并返回结果,运行结果如下:

results的值是MapReduce的处理结果,timeMillis指明花费的时间;counts中input指明了输入的文档数,emit指明了在map中调用emit的次数,reduce指明了reduce的次数(本例中如果单次次数为1则不需要reduce),output指明了输出的文档数目。

可以看到,键_id不再是自动生成,而是被reduce中的key取代。当然,也可以将结果输入到一个新的collection中,例如:之后查看mr_result集合中的内容即可:也可以使用db.runCommand执行mapreduce任务,这种方法为开发者提供了更多的选项,具体请见资料[1]。资料[2][3][4]提供了关于mapreduce更全面的内容。资料[5]给出了优化mapreduce任务的方法,资料[6]是资料[5]的一篇中文翻译。

应该注意的是,资料[5]中提到使用ScopedThread()创建线程,笔者在GUI工具Robomongo的shell中运行 new ScopedThread()时候报错: ReferenceError: ScopedThread is not defined (shell):1

不过在mongo shell中可以正常运行:

如果使用其他编程语言管理MongoDB,要用到线程时,应该使用该编程语言内置的线程。

关于mongodb实现的mapreduce,个人觉得如果支持多个MR任务平滑过渡就更好了。

推荐整理分享MongoDB中MapReduce编程模型使用实例,希望有所帮助,仅作参考,欢迎阅读内容。

MongoDB中MapReduce编程模型使用实例

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

MongoDB Remove函数的3个常见用法 在MongoDB中,db.collection.remove()方法用来从文档中删除文档。可以从一个集合中删除所有文档,删除匹配一个条件的所有文档,或者限制操作只删除一条文

MongoDB修改数据的2种方法 在MongoDB中,db.collection.ipdate()和db.collection.save()方法都可以修改集合中已存在的文档。db.collection.update()方法对修改提供额外的控制。例如,db.collectoin.upda

MongoDB查询操作限制返回字段的方法 映射(projection)声明用来限制所有查询匹配文档的返回字段。projection以文档的形式列举结果集中要包含或者排除的字段。可以指定要包含的字段(例如:

标签: MongoDB中MapReduce编程模型使用实例

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

上一篇:MongoDB中javascript脚本编程简介和入门实例(mongodb operator)

下一篇:MongoDB Remove函数的3个常见用法(mongodb reactive)

  • 提前报废的设备
  • 企业避税和逃税的关系
  • 委托外单位研发的研发费用加计扣除最新政策
  • 小规模纳税人免税销售额
  • 建筑施工企业涉税问题
  • 支票盖财务章盖在哪里
  • 销售货物产生的运费如何开票
  • 行政事业单位凭证培训课件
  • 丢失发票已报税证明单取消
  • 红字发票是否要修改往期申报表
  • 一般纳税人应交增值税明细科目设置
  • 建筑业企业分包出克的是否能上报
  • 未分配利润转增股本需要缴纳企业所得税吗
  • 研发新产品成功案例简短
  • 年末计提存货跌价准备
  • 职工宿舍租赁费
  • 所得税汇算有研发费用可以不享受加计扣除吗
  • 金税盘里的增值税怎么算
  • 汇兑损失的原因
  • 进口商品买卖的关键环节
  • 企业购入交易性金融资产支付的交易费用
  • 所有者权是否益包括未交出资吗?
  • 本年利润总账需要本年合计吗?
  • 公司净资产怎么算出来的
  • 普通发票的进项票怎么做分录
  • linux使用docker
  • 应收账款转让分录
  • 企业为员工提供服务要交增值税吗
  • php数据库删除数据
  • 待报解预算收入是社保扣费吗
  • 固定资产的使用寿命超过一个会计年度
  • 未分配利润可以弥补亏损吗
  • u-net优点
  • html流光按钮
  • 第一章 使用layui的表格和表单
  • 区块链教程大全
  • 支付职工差旅费发生的现金流出
  • 跨期发票的形成条件
  • 注解注入
  • 生产油漆涂料的物质
  • mysql性能提升
  • mongodb导出数据库数据文件
  • 已抵扣发票在什么地方查
  • 开票信息修改
  • sqldbmon
  • 企业取得投资收益要交税吗
  • 公司为职工提供免费午餐需要交纳个人所得税吗?
  • 汇算清缴 房租
  • 财产转让收入属于什么收入
  • 税务稽查补缴上年所得税分录
  • 利息支出应计入什么科目
  • 企业取得的跨期业务
  • 子公司注销如何注销
  • 净资产利润率的公式是什么
  • 公司购买银行理财产品收益交什么税
  • 固定资产的折旧标准
  • 进项税和销项税怎么理解
  • 测绘费发票图片
  • 计提房产税需要附凭证吗
  • mysql索引类型及原理
  • 服务器系统2003
  • mac电脑快速查询
  • windows7问题解决方案
  • 苹果mac浏览器
  • vnc for linux
  • 进程lsass.exe
  • elccest.exe是间谍广告程序吗 elccest进程有什么作用
  • 电脑xp系统如何
  • 在windows xp
  • android开发工程师案例教程源码
  • 辅组什么词?
  • 在一个批处理系统中
  • Android studio第一行报错
  • 命令适用于
  • python中求最大值和最小值的函数
  • Unity3D游戏开发标准教程
  • 一不小心做错事男朋友就开始说我
  • 中建七局企业精神是什么
  • 浙江摩托车上牌条件
  • 国家个人所得税征收标准
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设