注:作者使用的mongodb版本为2.4.7。
入门例子
conn = new Mongo(); db = conn.getDB("db-name"); //选择数据库 db.auth("user-name","password"); //用户验证var map = function() { split_result = this.sentence.split(" "); for (var i in split_result) { var word = split_result[i].replace(/(^\s*)|(\s*$)/g,"").toLowerCase(); //去除了单词两边可能的空格,并将单词转换为小写 if (word.length != 0) { emit(word, 1); } } } var reduce = function(key, values) { print(key+":"+Array.sum(values)); return Array.sum(values); } db.data.mapReduce( map, reduce, {out:{merge:"mr_result"}} )
保存为test01.js,在终端中运行:
$ mongo test01.js
运行结束后可以在集合mr_result中查看mapreduce结果。
值得注意的是,在js脚本中如果直接:
db.mr_result.find();
是无法输出结果的。
应该使用下面的方式输出结果:
conn = new Mongo(); db = conn.getDB("db-name"); //选择数据库 db.auth("user-name","password"); //用户验证var cursor = db.mr_result.find(); while(cursor.hasNext()) { r = cursor.next(); print(r["_id"] + "\t" + r["value"]); }
保存为test02.js,运行:
$ mongo test02.js
结果如下:
a 1 code 1 collection 1 consider 1 contains 1 documents 1 error 1 follow 1 following 3 found 1 get 1 i 2 in 1 link 1 map-reduce 1 of 1 on 1 operations 1 orders 1 prototype 1 that 1 the 4 this 1 when 1
使用load()函数
load()函数用于引入其他文件,这为代码重用提供了便利。 最简单的情形是,把数据库连接操作的代码放在一个单独的文件里,在当前目录建立lib,在lib目录下创建文件base_operation.js,内容如下:
function BaseOperation() { /* 连接数据库,返回连接对象 */ this.getDB = function() { conn = new Mongo(); db = conn.getDB("db-name"); db.auth("user-name","password"); return db; } }
在当前目录下建立文件test03.js,内容如下:
load("lib/base_operation.js"); BO = new BaseOperation(); db = BO.getDB();var cursor = db.mr_result.find(); while(cursor.hasNext()) { r = cursor.next(); print(r["_id"] + "\t" + r["value"]); }
运行test03.js的效果和test02.js相同。
© 版权声明
本文刊载的所有内容,包括文字、图片、音频、视频、软件、程序、以及网页版式设计等部门来源于互联网,版权均归原作者所有!本网站提供的内容服务于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯本网站及相关权利人的合法权利。
联系信息:邮箱aoxolcom@163.com或见网站底部。
联系信息:邮箱aoxolcom@163.com或见网站底部。
THE END
请登录后发表评论
注册
社交帐号登录