成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

MongoDB中MapReduce使用

Near_Li / 2746人閱讀

摘要:本文我們就來看看中的使用。結(jié)果如下錢鐘書宋詩(shī)選注談藝錄魯迅彷徨實(shí)現(xiàn)我們也可以利用命令來執(zhí)行。

玩過Hadoop的小伙伴對(duì)MapReduce應(yīng)該不陌生,MapReduce的強(qiáng)大且靈活,它可以將一個(gè)大問題拆分為多個(gè)小問題,將各個(gè)小問題發(fā)送到不同的機(jī)器上去處理,所有的機(jī)器都完成計(jì)算后,再將計(jì)算結(jié)果合并為一個(gè)完整的解決方案,這就是所謂的分布式計(jì)算。本文我們就來看看MongoDB中MapReduce的使用。

本文是MongoDB系列的第十四篇文章,了解前面的文章有助于更好的理解本文:


1.Linux上安裝MongoDB
2.MongoDB基本操作
3.MongoDB數(shù)據(jù)類型
4.MongoDB文檔更新操作
5.MongoDB文檔查詢操作(一)
6.MongoDB文檔查詢操作(二)
7.MongoDB文檔查詢操作(三)
8.MongoDB查看執(zhí)行計(jì)劃
9.初識(shí)MongoDB中的索引
10.MongoDB中各種類型的索引
11.MongoDB固定集合
12.MongoDB管道操作符(一)
13.MongoDB管道操作符(二)


mapReduce

MongoDB中的MapReduce可以用來實(shí)現(xiàn)更復(fù)雜的聚合命令,使用MapReduce主要實(shí)現(xiàn)兩個(gè)函數(shù):map函數(shù)和reduce函數(shù),map函數(shù)用來生成鍵值對(duì)序列,map函數(shù)的結(jié)果作為reduce函數(shù)的參數(shù),reduce函數(shù)中再做進(jìn)一步的統(tǒng)計(jì),比如我的數(shù)據(jù)集如下:

{"_id" : ObjectId("59fa71d71fd59c3b2cd908d7"),"name" : "魯迅","book" : "吶喊","price" : 38.0,"publisher" : "人民文學(xué)出版社"}
{"_id" : ObjectId("59fa71d71fd59c3b2cd908d8"),"name" : "曹雪芹","book" : "紅樓夢(mèng)","price" : 22.0,"publisher" : "人民文學(xué)出版社"}
{"_id" : ObjectId("59fa71d71fd59c3b2cd908d9"),"name" : "錢鐘書","book" : "宋詩(shī)選注","price" : 99.0,"publisher" : "人民文學(xué)出版社"}
{"_id" : ObjectId("59fa71d71fd59c3b2cd908da"),"name" : "錢鐘書","book" : "談藝錄","price" : 66.0,"publisher" : "三聯(lián)書店"}
{"_id" : ObjectId("59fa71d71fd59c3b2cd908db"),"name" : "魯迅","book" : "彷徨","price" : 55.0,"publisher" : "花城出版社"}

假如我想查詢每位作者所出的書的總價(jià),操作如下:

var map=function(){emit(this.name,this.price)}
var reduce=function(key,value){return Array.sum(value)}
var options={out:"totalPrice"}
db.sang_books.mapReduce(map,reduce,options);
db.totalPrice.find()

emit函數(shù)主要用來實(shí)現(xiàn)分組,接收兩個(gè)參數(shù),第一個(gè)參數(shù)表示分組的字段,第二個(gè)參數(shù)表示要統(tǒng)計(jì)的數(shù)據(jù),reduce來做具體的數(shù)據(jù)處理操作,接收兩個(gè)參數(shù),對(duì)應(yīng)emit方法的兩個(gè)參數(shù),這里使用了Array中的sum函數(shù)對(duì)price字段進(jìn)行自加處理,options中定義了將結(jié)果輸出的集合,屆時(shí)我們將在這個(gè)集合中去查詢數(shù)據(jù),默認(rèn)情況下,這個(gè)集合即使在數(shù)據(jù)庫(kù)重啟后也會(huì)保留,并且保留集合中的數(shù)據(jù)。查詢結(jié)果如下:

{
    "_id" : "曹雪芹",
    "value" : 22.0
}
{
    "_id" : "錢鐘書",
    "value" : 165.0
}
{
    "_id" : "魯迅",
    "value" : 93.0
}

再比如我想查詢每位作者出了幾本書,如下:

var map=function(){emit(this.name,1)}
var reduce=function(key,value){return Array.sum(value)}
var options={out:"bookNum"}
db.sang_books.mapReduce(map,reduce,options);
db.bookNum.find()

查詢結(jié)果如下:

{
    "_id" : "曹雪芹",
    "value" : 1.0
}
{
    "_id" : "錢鐘書",
    "value" : 2.0
}
{
    "_id" : "魯迅",
    "value" : 2.0
}

將每位作者的書列出來,如下:

var map=function(){emit(this.name,this.book)}
var reduce=function(key,value){return value.join(",")}
var options={out:"books"}
db.sang_books.mapReduce(map,reduce,options);
db.books.find()

結(jié)果如下:

{
    "_id" : "曹雪芹",
    "value" : "紅樓夢(mèng)"
}
{
    "_id" : "錢鐘書",
    "value" : "宋詩(shī)選注,談藝錄"
}
{
    "_id" : "魯迅",
    "value" : "吶喊,彷徨"
}

比如查詢每個(gè)人售價(jià)在¥40以上的書:

var map=function(){emit(this.name,this.book)}
var reduce=function(key,value){return value.join(",")}
var options={query:{price:{$gt:40}},out:"books"}
db.sang_books.mapReduce(map,reduce,options);
db.books.find()

query表示對(duì)查到的集合再進(jìn)行篩選。

結(jié)果如下:

{
    "_id" : "錢鐘書",
    "value" : "宋詩(shī)選注,談藝錄"
}
{
    "_id" : "魯迅",
    "value" : "彷徨"
}
runCommand實(shí)現(xiàn)

我們也可以利用runCommand命令來執(zhí)行MapReduce。格式如下:

db.runCommand(
               {
                 mapReduce: ,
                 map: ,
                 reduce: ,
                 finalize: ,
                 out: ,
                 query: ,
                 sort: ,
                 limit: ,
                 scope: ,
                 jsMode: ,
                 verbose: ,
                 bypassDocumentValidation: ,
                 collation: 
               }
             )

含義如下:

參數(shù) 含義
mapReduce 表示要操作的集合
map map函數(shù)
reduce reduce函數(shù)
finalize 最終處理函數(shù)
out 輸出的集合
query 對(duì)結(jié)果進(jìn)行過濾
sort 對(duì)結(jié)果排序
limit 返回的結(jié)果數(shù)
scope 設(shè)置參數(shù)值,在這里設(shè)置的值在map、reduce、finalize函數(shù)中可見
jsMode 是否將map執(zhí)行的中間數(shù)據(jù)由javascript對(duì)象轉(zhuǎn)換成BSON對(duì)象,默認(rèn)為false
verbose 是否顯示詳細(xì)的時(shí)間統(tǒng)計(jì)信息
bypassDocumentValidation 是否繞過文檔驗(yàn)證
collation 其他一些校對(duì)

如下操作,表示執(zhí)行MapReduce操作并對(duì)統(tǒng)計(jì)的集合限制返回條數(shù),限制返回條數(shù)之后再進(jìn)行統(tǒng)計(jì)操作,如下:

var map=function(){emit(this.name,this.book)}
var reduce=function(key,value){return value.join(",")}
db.runCommand({mapreduce:"sang_books",map,reduce,out:"books",limit:4,verbose:true})
db.books.find()

執(zhí)行結(jié)果如下:

{
    "_id" : "曹雪芹",
    "value" : "紅樓夢(mèng)"
}
{
    "_id" : "錢鐘書",
    "value" : "宋詩(shī)選注,談藝錄"
}
{
    "_id" : "魯迅",
    "value" : "吶喊"
}

小伙伴們看到,魯迅有一本書不見了,就是因?yàn)閘imit是先限制集合返回條數(shù),然后再執(zhí)行統(tǒng)計(jì)操作。

finalize操作表示最終處理函數(shù),如下:

var f1 = function(key,reduceValue){var obj={};obj.author=key;obj.books=reduceValue; return obj}
var map=function(){emit(this.name,this.book)}
var reduce=function(key,value){return value.join(",")}
db.runCommand({mapreduce:"sang_books",map,reduce,out:"books",finalize:f1})
db.books.find()

f1第一個(gè)參數(shù)key表示emit中的第一個(gè)參數(shù),第二個(gè)參數(shù)表示reduce的執(zhí)行結(jié)果,我們可以在f1中對(duì)這個(gè)結(jié)果進(jìn)行再處理,結(jié)果如下:

{
    "_id" : "曹雪芹",
    "value" : {
        "author" : "曹雪芹",
        "books" : "紅樓夢(mèng)"
    }
}
{
    "_id" : "錢鐘書",
    "value" : {
        "author" : "錢鐘書",
        "books" : "宋詩(shī)選注,談藝錄"
    }
}
{
    "_id" : "魯迅",
    "value" : {
        "author" : "魯迅",
        "books" : "吶喊,彷徨"
    }
}

scope則可以用來定義一個(gè)在map、reduce和finalize中都可見的變量,如下:

var f1 = function(key,reduceValue){var obj={};obj.author=key;obj.books=reduceValue;obj.sang=sang; return obj}
var map=function(){emit(this.name,this.book)}
var reduce=function(key,value){return value.join(",--"+sang+"--,")}
db.runCommand({mapreduce:"sang_books",map,reduce,out:"books",finalize:f1,scope:{sang:"haha"}})
db.books.find()

執(zhí)行結(jié)果如下:

{
    "_id" : "曹雪芹",
    "value" : {
        "author" : "曹雪芹",
        "books" : "紅樓夢(mèng)",
        "sang" : "haha"
    }
}
{
    "_id" : "錢鐘書",
    "value" : {
        "author" : "錢鐘書",
        "books" : "宋詩(shī)選注,--haha--,談藝錄",
        "sang" : "haha"
    }
}
{
    "_id" : "魯迅",
    "value" : {
        "author" : "魯迅",
        "books" : "吶喊,--haha--,彷徨",
        "sang" : "haha"
    }
}

好了,MongoDB中的MapReduce我們就先說到這里,小伙伴們有問題歡迎留言討論。

參考資料:

1.《MongoDB權(quán)威指南第2版》
2.mongodb mapreduce小試
3.mongoDB--mapreduce用法詳解(未找到原始出處)

更多資料請(qǐng)關(guān)注公眾號(hào):

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/19151.html

相關(guān)文章

  • MongoDB指南---17、MapReduce

    摘要:操作花費(fèi)的時(shí)間,單位是毫秒。處理完成后,會(huì)自動(dòng)將臨時(shí)集合的名字更改為你指定的集合名,這個(gè)重命名的過程是原子性的。作用域在這些函數(shù)內(nèi)部是不變的。上一篇文章指南聚合下一篇文章指南聚合命令 上一篇文章:MongoDB指南---16、聚合下一篇文章:MongoDB指南---18、聚合命令 MapReduce是聚合工具中的明星,它非常強(qiáng)大、非常靈活。有些問題過于復(fù)雜,無法使用聚合框架的查詢語言...

    jonh_felix 評(píng)論0 收藏0
  • MongoDB指南---17、MapReduce

    摘要:操作花費(fèi)的時(shí)間,單位是毫秒。處理完成后,會(huì)自動(dòng)將臨時(shí)集合的名字更改為你指定的集合名,這個(gè)重命名的過程是原子性的。作用域在這些函數(shù)內(nèi)部是不變的。上一篇文章指南聚合下一篇文章指南聚合命令 上一篇文章:MongoDB指南---16、聚合下一篇文章:MongoDB指南---18、聚合命令 MapReduce是聚合工具中的明星,它非常強(qiáng)大、非常靈活。有些問題過于復(fù)雜,無法使用聚合框架的查詢語言...

    pubdreamcc 評(píng)論0 收藏0
  • MongoDB優(yōu)化之倒排索引

    摘要:簡(jiǎn)單地說,倒排索引就是把與對(duì)調(diào)之后的索引,構(gòu)建倒排索引的目的是提升搜索性能。本文將介紹中兩種構(gòu)建倒排索引的方法與。 摘要: 為MongoDB中的數(shù)據(jù)構(gòu)建倒排索引(Inverted Index),然后緩存到內(nèi)存中,可以大幅提升搜索性能。本文將通過為電影數(shù)據(jù)構(gòu)建演員索引,介紹兩種構(gòu)建倒排索引的方法:MapReduce和Aggregation Pipeline。 GitHub地址: 作者:...

    Nino 評(píng)論0 收藏0
  • MongoDbMapReduce

    摘要:中的相當(dāng)于中的,所以在上使用進(jìn)行并行統(tǒng)計(jì)比較容易。使用要實(shí)現(xiàn)兩個(gè)函數(shù)和函數(shù),函數(shù)調(diào)用,遍歷中所有記錄,將與傳遞給函數(shù)進(jìn)行處理。由此可見,這并不是成線性增長(zhǎng),而是隨著數(shù)據(jù)量增長(zhǎng),時(shí)間也在不斷的遞增,而且單位時(shí)間內(nèi)增長(zhǎng)的數(shù)據(jù)量也會(huì)減少。 MongoDB中的MapReduce相當(dāng)于Mysql中的group by, 所以在MongoDb上使用Map/Reduce進(jìn)行并行統(tǒng)計(jì)比較容易。使用...

    avwu 評(píng)論0 收藏0
  • 「譯」 MapReduce in MongoDB

    摘要:在第行中,我們會(huì)從集合取得結(jié)果并顯示它。的邏輯在中,我們要以性別作為,然后以作為。年齡是用來做計(jì)算用的,而名字只是用來顯示給人看的。我們要檢查所有和性別相關(guān)的年齡,找到年齡最大和最小的用戶。 在這篇文章里面,我們會(huì)演示如何在 MongoDB 中使用 MapReduce 操作。我們會(huì)用 dummy-json 這個(gè)包來生成一些虛假的數(shù)據(jù),然后用 Mongojs 如果想要快速看到結(jié)果,可以到...

    ConardLi 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<