亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MongoDB中javascript腳本編程簡(jiǎn)介和入門實(shí)例

 更新時(shí)間:2014年04月26日 09:50:56   作者:  
作為一個(gè)數(shù)據(jù)庫(kù),MongoDB有一個(gè)很大的優(yōu)勢(shì)——它使用js管理數(shù)據(jù)庫(kù),所以也能夠使用js腳本進(jìn)行復(fù)雜的管理——這種方法非常靈活

注:作者使用的mongodb版本為2.4.7。

入門例子

復(fù)制代碼 代碼如下:

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)行:

復(fù)制代碼 代碼如下:
$ mongo test01.js

運(yùn)行結(jié)束后可以在集合mr_result中查看mapreduce結(jié)果。

值得注意的是,在js腳本中如果直接:

復(fù)制代碼 代碼如下:
db.mr_result.find();

是無(wú)法輸出結(jié)果的。

應(yīng)該使用下面的方式輸出結(jié)果:

復(fù)制代碼 代碼如下:
conn = new Mongo();
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)行:
復(fù)制代碼 代碼如下:
$ mongo test02.js

結(jié)果如下:
復(fù)制代碼 代碼如下:

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)容如下:

復(fù)制代碼 代碼如下:

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)容如下:
復(fù)制代碼 代碼如下:

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相同。

相關(guān)文章

  • mongodb權(quán)限設(shè)置之添加管理員、普通用戶的方法

    mongodb權(quán)限設(shè)置之添加管理員、普通用戶的方法

    這篇文章主要介紹了mongodb添加管理員、普通用戶的方法,同時(shí)介紹了mongodb開啟權(quán)限認(rèn)證后PHP客戶端的兩種連接方法,需要的朋友可以參考下
    2014-06-06
  • mongodb出現(xiàn)id重復(fù)問(wèn)題的簡(jiǎn)單解決辦法

    mongodb出現(xiàn)id重復(fù)問(wèn)題的簡(jiǎn)單解決辦法

    近期在使用mongodb的過(guò)程中遇到一次表中有_id字段重復(fù)的記錄(相同_id的有兩條),著實(shí)嚇了一大跳,這篇文章主要給大家介紹了關(guān)于mongodb出現(xiàn)id重復(fù)問(wèn)題的簡(jiǎn)單解決辦法,需要的朋友可以參考下
    2021-12-12
  • MongoDB高效讀寫海量數(shù)據(jù)的方法

    MongoDB高效讀寫海量數(shù)據(jù)的方法

    這篇文章介紹了MongoDB高效讀寫海量數(shù)據(jù)的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-02-02
  • CentOS7下安裝MongoDB數(shù)據(jù)庫(kù)過(guò)程

    CentOS7下安裝MongoDB數(shù)據(jù)庫(kù)過(guò)程

    大家好,本篇文章主要講的是CentOS7下安裝MongoDB數(shù)據(jù)庫(kù)過(guò)程,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • Mongodb中嵌套文檔數(shù)組查詢操作

    Mongodb中嵌套文檔數(shù)組查詢操作

    這篇文章主要介紹了Mongodb對(duì)嵌套文檔數(shù)組進(jìn)行查詢操作,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-07-07
  • MongoDB導(dǎo)出查詢結(jié)果到文件例子

    MongoDB導(dǎo)出查詢結(jié)果到文件例子

    這篇文章主要介紹了MongoDB導(dǎo)出查詢結(jié)果到文件例子,本文直接給出示例代碼,簡(jiǎn)潔易懂,需要的朋友可以參考下
    2015-02-02
  • MongoDB入門教程之主從復(fù)制配置詳解

    MongoDB入門教程之主從復(fù)制配置詳解

    這篇文章主要介紹了MongoDB入門教程之主從復(fù)制配置詳解,本文環(huán)境是windows+MongoDB,操作部分使用圖片來(lái)講解,需要的朋友可以參考下
    2014-08-08
  • MongoDB修改、刪除文檔的域?qū)傩詫?shí)例

    MongoDB修改、刪除文檔的域?qū)傩詫?shí)例

    這篇文章主要介紹了MongoDB修改、刪除文檔的域?qū)傩詫?shí)例,本文講解了刪除集合中所有文檔的一個(gè)域、同時(shí)刪除多個(gè)域、同時(shí)刪除和新增域,需要的朋友可以參考下
    2015-02-02
  • 分析MongoDB和MySQL各自的關(guān)鍵特性、差別和優(yōu)勢(shì)

    分析MongoDB和MySQL各自的關(guān)鍵特性、差別和優(yōu)勢(shì)

    MongoDB 和 MySQL 都是不錯(cuò)的數(shù)據(jù)庫(kù),都具有優(yōu)良的性能。然而,它們是否成功取決于應(yīng)用場(chǎng)景。首先應(yīng)當(dāng)了解它們各自不同的運(yùn)行環(huán)境,而不能只比較各自的優(yōu)點(diǎn)和缺點(diǎn)。因此,在本文中,我們將探討 MongoDB 和 MySQL 各自的關(guān)鍵特性、差別和優(yōu)勢(shì)。
    2021-06-06
  • MongoDB插入、更新、刪除文檔實(shí)現(xiàn)代碼

    MongoDB插入、更新、刪除文檔實(shí)現(xiàn)代碼

    本文通過(guò)實(shí)例代碼給大家簡(jiǎn)單介紹了mongodb插入、更新、刪除文檔的方法,需要的的朋友參考下吧
    2017-04-04

最新評(píng)論