MongoDB中javascript腳本編程簡(jiǎn)介和入門實(shí)例
注:作者使用的mongodb版本為2.4.7。
入門例子
conn = new Mongo();
db = conn.getDB("db-name"); //選擇數(shù)據(jù)庫(kù)
db.auth("user-name","password"); //用戶驗(yàn)證
var map = function() {
split_result = this.sentence.split(" ");
for (var i in split_result) {
var word = split_result[i].replace(/(^\s*)|(\s*$)/g,"").toLowerCase(); //去除了單詞兩邊可能的空格,并將單詞轉(zhuǎn)換為小寫
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,在終端中運(yùn)行:
運(yùn)行結(jié)束后可以在集合mr_result中查看mapreduce結(jié)果。
值得注意的是,在js腳本中如果直接:
是無法輸出結(jié)果的。
應(yīng)該使用下面的方式輸出結(jié)果:
db = conn.getDB("db-name"); //選擇數(shù)據(jù)庫(kù)
db.auth("user-name","password"); //用戶驗(yàn)證
var cursor = db.mr_result.find();
while(cursor.hasNext()) {
r = cursor.next();
print(r["_id"] + "\t" + r["value"]);
}
保存為test02.js,運(yùn)行:
結(jié)果如下:
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()函數(shù)
load()函數(shù)用于引入其他文件,這為代碼重用提供了便利。 最簡(jiǎn)單的情形是,把數(shù)據(jù)庫(kù)連接操作的代碼放在一個(gè)單獨(dú)的文件里,在當(dāng)前目錄建立lib,在lib目錄下創(chuàng)建文件base_operation.js,內(nèi)容如下:
function BaseOperation() {
/*
連接數(shù)據(jù)庫(kù),返回連接對(duì)象
*/
this.getDB = function() {
conn = new Mongo();
db = conn.getDB("db-name");
db.auth("user-name","password");
return db;
}
}
在當(dāng)前目錄下建立文件test03.js,內(nèi)容如下:
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"]);
}
運(yùn)行test03.js的效果和test02.js相同。
- MongoDB快速入門筆記(八)之MongoDB的java驅(qū)動(dòng)操作代碼講解
- MongoDB 快速入門
- MongoDB入門教程之Windows下的MongoDB數(shù)據(jù)庫(kù)安裝圖解
- MongoDB入門教程(包含安裝、常用命令、相關(guān)概念、使用技巧、常見操作等)
- MongoDB快速入門筆記(七)MongoDB的用戶管理操作
- MongoDB入門教程之C#驅(qū)動(dòng)操作實(shí)例
- MongoDB入門教程之主從復(fù)制配置詳解
- MongoDB入門教程之細(xì)說MongoDB數(shù)據(jù)庫(kù)的增刪查改操作
- 零基礎(chǔ)搭建Node.js、Express、Ejs、Mongodb服務(wù)器及應(yīng)用開發(fā)入門
- MongoDB 入門指南
相關(guān)文章
windows與mac安裝mongodb數(shù)據(jù)庫(kù)的方法步驟與注意事項(xiàng)
今天小編就為大家分享一篇關(guān)于windows與mac安裝mongodb數(shù)據(jù)庫(kù)的方法步驟與注意事項(xiàng),小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-03-03
大數(shù)據(jù)環(huán)境下mongoDB為何要加索引淺析
這篇文章主要給大家介紹了關(guān)于大數(shù)據(jù)環(huán)境下mongoDB為何要加索引的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用mongoDB具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
Ubuntu中安裝MongoDB及執(zhí)行一些簡(jiǎn)單操作筆記
這篇文章主要介紹了Ubuntu中安裝MongoDB及執(zhí)行一些簡(jiǎn)單操作筆記,本文同時(shí)給出了查看已有數(shù)據(jù)庫(kù)、刪除數(shù)據(jù)庫(kù)、創(chuàng)建數(shù)據(jù)庫(kù)等操作命令實(shí)例,需要的朋友可以參考下2014-09-09
MongoDB數(shù)據(jù)庫(kù)用戶角色和權(quán)限管理詳解
這篇文章主要給大家介紹了關(guān)于MongoDB數(shù)據(jù)庫(kù)用戶角色和權(quán)限管理的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
Windows系統(tǒng)下安裝Mongodb 3.2.x的步驟詳解
mongodb3.x版本有好多新功能,關(guān)于這方面參考官網(wǎng)即可,下面這篇文章主要給大家介紹了在Windows系統(tǒng)下安裝Mongodb 3.2.x的詳細(xì)步驟,文中介紹的非常詳細(xì),需要的朋友們可以參考學(xué)習(xí),下面來一起看看吧。2017-03-03

