亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > MongoDB中MapReduce的使用方法詳解

MongoDB中MapReduce的使用方法詳解

熱門標(biāo)簽:蘋果汽車租賃店地圖標(biāo)注 電銷機(jī)器人是什么軟件 云南外呼系統(tǒng) 呼和浩特電銷外呼系統(tǒng)加盟 廣州長安公司怎樣申請400電話 濟(jì)南電銷機(jī)器人加盟公司 怎么投訴地圖標(biāo)注 老虎洗衣店地圖標(biāo)注 杭州人工電銷機(jī)器人價(jià)格

前言

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

打算用mongodb mapreduce之前一定要知道的事!!!

mapreduce其實(shí)是分批處理數(shù)據(jù)的,每一百次重新reduce處理,所以到reduce里的數(shù)據(jù)如果是101條,那就會分2次進(jìn)入。

這導(dǎo)致的問題就是在reduce中 如果 初始化 var count = 0;在循環(huán)中 count ++,最后輸出的是1???

避免都方法是,把數(shù)據(jù)存在返回的value里,這個(gè)value是會在循環(huán)進(jìn)入reduce的時(shí)候重用的。在循環(huán)中 count += value.count就能把之前都100加上了!!!

還有如果只有一條數(shù)據(jù),那它不會進(jìn)入reduce,會直接返回。

下面是具體例子:

string map = @"
function() {
var view = this;
emit(view.activity, {pv: 1});
}";
string reduce = @" 
function(key, values) {
var result = {pv: 0};
values.forEach(function(value){ 
result.pv += value.pv;
});
return result;
}";
string finalize = @"
function(key, value){
return value;
}";

mapReduce

MongoDB中的MapReduce可以用來實(shí)現(xiàn)更復(fù)雜的聚合命令,使用MapReduce主要實(shí)現(xiàn)兩個(gè)函數(shù):map函數(shù)和reduce函數(shù),map函數(shù)用來生成鍵值對序列,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" : "紅樓夢","price" : 22.0,"publisher" : "人民文學(xué)出版社"}
{"_id" : ObjectId("59fa71d71fd59c3b2cd908d9"),"name" : "錢鐘書","book" : "宋詩選注","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ù),對應(yīng)emit方法的兩個(gè)參數(shù),這里使用了Array中的sum函數(shù)對price字段進(jìn)行自加處理,options中定義了將結(jié)果輸出的集合,屆時(shí)我們將在這個(gè)集合中去查詢數(shù)據(jù),默認(rèn)情況下,這個(gè)集合即使在數(shù)據(jù)庫重啟后也會保留,并且保留集合中的數(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" : "紅樓夢"
}
{
 "_id" : "錢鐘書",
 "value" : "宋詩選注,談藝錄"
}
{
 "_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表示對查到的集合再進(jìn)行篩選。

結(jié)果如下:

{
 "_id" : "錢鐘書",
 "value" : "宋詩選注,談藝錄"
}
{
 "_id" : "魯迅",
 "value" : "彷徨"
}

runCommand實(shí)現(xiàn)

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

db.runCommand(
    {
     mapReduce: collection>,
     map: function>,
     reduce: function>,
     finalize: function>,
     out: output>,
     query: document>,
     sort: document>,
     limit: number>,
     scope: document>,
     jsMode: boolean>,
     verbose: boolean>,
     bypassDocumentValidation: boolean>,
     collation: document>
    }
    )

含義如下:

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

如下操作,表示執(zhí)行MapReduce操作并對統(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" : "紅樓夢"
}
{
 "_id" : "錢鐘書",
 "value" : "宋詩選注,談藝錄"
}
{
 "_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中對這個(gè)結(jié)果進(jìn)行再處理,結(jié)果如下:

{
 "_id" : "曹雪芹",
 "value" : {
  "author" : "曹雪芹",
  "books" : "紅樓夢"
 }
}
{
 "_id" : "錢鐘書",
 "value" : {
  "author" : "錢鐘書",
  "books" : "宋詩選注,談藝錄"
 }
}
{
 "_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" : "紅樓夢",
  "sang" : "haha"
 }
}
{
 "_id" : "錢鐘書",
 "value" : {
  "author" : "錢鐘書",
  "books" : "宋詩選注,--haha--,談藝錄",
  "sang" : "haha"
 }
}
{
 "_id" : "魯迅",
 "value" : {
  "author" : "魯迅",
  "books" : "吶喊,--haha--,彷徨",
  "sang" : "haha"
 }
}

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

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

參考資料:

1.《MongoDB權(quán)威指南第2版》

2.mongodb mapreduce小試

3.mongoDB--mapreduce用法詳解(未找到原始出處)

您可能感興趣的文章:
  • Javascript面試經(jīng)典套路reduce函數(shù)查重
  • MapReduce核心思想圖文詳解
  • shuffle的關(guān)鍵階段sort(Map端和Reduce端)源碼分析
  • 通用MapReduce程序復(fù)制HBase表數(shù)據(jù)
  • Array數(shù)組對象中的forEach、map、filter及reduce詳析
  • 對tf.reduce_sum tensorflow維度上的操作詳解
  • js數(shù)組方法reduce經(jīng)典用法代碼分享
  • Java/Web調(diào)用Hadoop進(jìn)行MapReduce示例代碼
  • 詳解JS數(shù)組Reduce()方法詳解及高級技巧
  • js中的reduce()函數(shù)講解

標(biāo)簽:遼陽 興安盟 雞西 自貢 泰安 廈門 玉林 無錫

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MongoDB中MapReduce的使用方法詳解》,本文關(guān)鍵詞  MongoDB,中,MapReduce,的,使用方法,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MongoDB中MapReduce的使用方法詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于MongoDB中MapReduce的使用方法詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    天堂网中文在线| 可以免费看毛片的网站| 欧美a级片免费看| 亚洲精品永久一区| 黄视频网站在线观看| 欧美激情一区二区三区视频 | 99久久精品费精品国产一区二区| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 黄视频网站在线观看| 国产国语在线播放视频| 国产高清在线精品一区a| 日日爽天天| 亚洲 国产精品 日韩| 国产美女在线一区二区三区| 亚洲天堂免费| 成人免费一级纶理片| 黄色短视屏| 欧美1区| 99久久精品国产麻豆| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 精品视频在线观看视频免费视频| 日本伦理片网站| 免费一级生活片| 日韩免费在线| 国产伦精品一区三区视频| 国产伦久视频免费观看 视频| 一本伊大人香蕉高清在线观看| 91麻豆精品国产自产在线 | 国产伦久视频免费观看视频| 国产网站免费观看| 久久成人亚洲| 日日夜夜婷婷| 精品美女| 日韩一级黄色大片| 九九久久国产精品大片| 午夜欧美成人香蕉剧场| 亚州视频一区二区| 在线观看导航| 精品视频在线看| 成人高清视频免费观看| 黄视频网站在线观看| 日韩中文字幕在线观看视频| 日韩免费片| 毛片的网站| 亚洲 男人 天堂| 国产一区二区高清视频| 成人a级高清视频在线观看| 国产视频在线免费观看| 精品视频免费观看| 四虎影视库| 999久久狠狠免费精品| 日本免费乱人伦在线观看 | 国产成人啪精品| 欧美1区| 国产一区二区精品久久91| 99色吧| 四虎久久影院| 国产伦久视频免费观看视频| 精品久久久久久综合网| 亚久久伊人精品青青草原2020| 韩国毛片免费| 精品久久久久久影院免费| 美女免费毛片| 午夜在线影院| 日韩专区亚洲综合久久| 四虎影视库| 成人在免费观看视频国产| 国产a网| 国产一区免费在线观看| 一本高清在线| 国产一区二区精品久久| 精品视频免费看| 天天色色网| 国产91丝袜高跟系列| 在线观看成人网| 国产一区二区福利久久| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产a视频| 国产亚洲精品aaa大片| 精品久久久久久中文字幕2017| 97视频免费在线观看| 免费的黄色小视频| 99久久精品国产国产毛片 | 精品国产一区二区三区免费| 亚欧乱色一区二区三区| 久久国产精品只做精品| 成人在免费观看视频国产| 九九热精品免费观看| 日韩中文字幕在线亚洲一区| 欧美另类videosbestsex视频| 日本特黄特色aa大片免费| 欧美a级片免费看| 亚洲精品中文一区不卡 | 精品国产一区二区三区免费| 免费毛片播放| 亚洲精品中文一区不卡 | 日日日夜夜操| 久久成人亚洲| 国产91素人搭讪系列天堂| 午夜在线亚洲| 国产精品自拍在线观看| 欧美激情伊人| 日韩在线观看网站| 日本在线不卡免费视频一区| 午夜在线影院| 国产a网| 色综合久久天天综线观看| 韩国三级香港三级日本三级la| 九九九国产| 久久成人性色生活片| 四虎影视精品永久免费网站| 欧美爱色| 香蕉视频三级| 欧美激情在线精品video| 午夜激情视频在线观看| 久久福利影视| 国产麻豆精品免费视频| 亚洲 国产精品 日韩| 久久福利影视| 国产网站在线| 久久国产精品自由自在| 黄色免费三级| 日韩字幕在线| 91麻豆精品国产自产在线| 台湾美女古装一级毛片| 欧美电影免费| 日韩中文字幕在线播放| 亚飞与亚基在线观看| 国产亚洲免费观看| 可以免费看污视频的网站| 日韩在线观看视频黄| 青草国产在线观看| 日本免费区| 国产视频久久久久| 91麻豆精品国产自产在线观看一区 | 欧美另类videosbestsex高清| 亚洲第一视频在线播放| 黄视频网站在线看| 高清一级毛片一本到免费观看| 色综合久久手机在线| 精品视频免费在线| 精品视频在线看| 一级片免费在线观看视频| 日本在线不卡视频| 日韩中文字幕一区二区不卡| 亚欧成人乱码一区二区| 午夜欧美福利| 青青久久精品国产免费看| 国产麻豆精品免费视频| 99久久精品国产麻豆| 国产一区二区高清视频| 国产综合91天堂亚洲国产| 91麻豆爱豆果冻天美星空| 亚洲 激情| 成人高清视频在线观看| 精品视频在线看 | 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产91精品一区| 台湾美女古装一级毛片| 中文字幕Aⅴ资源网| 欧美一级视频免费| 成人影院一区二区三区| 亚洲精品影院一区二区| 可以在线看黄的网站| 久草免费在线视频| 四虎影视库| 99色吧| 国产国语在线播放视频| 九九久久国产精品| 韩国三级视频网站| 天天色成人网| 日韩免费在线| 九九热精品免费观看| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产国产人免费视频成69堂| 欧美国产日韩精品| 精品在线视频播放| 久久久久久久免费视频| 国产一区二区精品尤物| 日本免费区| 日韩综合| 精品在线免费播放| 成人免费网站久久久| 午夜欧美福利| 成人免费网站久久久| 日韩免费在线视频| 天天色色网| 国产不卡福利| 精品久久久久久中文字幕2017| 国产国语在线播放视频| 久久国产一区二区| 国产原创中文字幕| 精品国产亚一区二区三区| 国产一区二区精品久久| 欧美1卡一卡二卡三新区| 九九久久99| 九九精品在线播放| 国产美女在线一区二区三区| 国产一级生活片|