亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁(yè) > 數(shù)據(jù)庫(kù) > MongoDB > 正文

MongoDB中MapReduce的使用方法詳解

2020-10-29 18:44:35
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

前言

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

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

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

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

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

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

下面是具體例子:

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可以用來(lái)實(shí)現(xiàn)更復(fù)雜的聚合命令,使用MapReduce主要實(shí)現(xiàn)兩個(gè)函數(shù):map函數(shù)和reduce函數(shù),map函數(shù)用來(lái)生成鍵值對(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" : "錢(qián)鐘書(shū)","book" : "宋詩(shī)選注","price" : 99.0,"publisher" : "人民文學(xué)出版社"}{"_id" : ObjectId("59fa71d71fd59c3b2cd908da"),"name" : "錢(qián)鐘書(shū)","book" : "談藝錄","price" : 66.0,"publisher" : "三聯(lián)書(shū)店"}{"_id" : ObjectId("59fa71d71fd59c3b2cd908db"),"name" : "魯迅","book" : "彷徨","price" : 55.0,"publisher" : "花城出版社"}

假如我想查詢每位作者所出的書(shū)的總價(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ù)主要用來(lái)實(shí)現(xiàn)分組,接收兩個(gè)參數(shù),第一個(gè)參數(shù)表示分組的字段,第二個(gè)參數(shù)表示要統(tǒng)計(jì)的數(shù)據(jù),reduce來(lái)做具體的數(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" : "錢(qián)鐘書(shū)", "value" : 165.0}{ "_id" : "魯迅", "value" : 93.0}

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

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" : "錢(qián)鐘書(shū)", "value" : 2.0}{ "_id" : "魯迅", "value" : 2.0}

將每位作者的書(shū)列出來(lái),如下:

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" : "錢(qián)鐘書(shū)", "value" : "宋詩(shī)選注,談藝錄"}{ "_id" : "魯迅", "value" : "吶喊,彷徨"}

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

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" : "錢(qián)鐘書(shū)", "value" : "宋詩(shī)選注,談藝錄"}{ "_id" : "魯迅", "value" : "彷徨"}

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

我們也可以利用runCommand命令來(lái)執(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 對(duì)結(jié)果進(jìn)行過(guò)濾
sort 對(duì)結(jié)果排序
limit 返回的結(jié)果數(shù)
scope 設(shè)置參數(shù)值,在這里設(shè)置的值在map、reduce、finalize函數(shù)中可見(jiàn)
jsMode 是否將map執(zhí)行的中間數(shù)據(jù)由javascript對(duì)象轉(zhuǎn)換成BSON對(duì)象,默認(rèn)為false
verbose 是否顯示詳細(xì)的時(shí)間統(tǒng)計(jì)信息
bypassDocumentValidation 是否繞過(guò)文檔驗(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" : "錢(qián)鐘書(shū)", "value" : "宋詩(shī)選注,談藝錄"}{ "_id" : "魯迅", "value" : "吶喊"}

小伙伴們看到,魯迅有一本書(shū)不見(jiàn)了,就是因?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" : "錢(qián)鐘書(shū)", "value" : {  "author" : "錢(qián)鐘書(shū)",  "books" : "宋詩(shī)選注,談藝錄" }}{ "_id" : "魯迅", "value" : {  "author" : "魯迅",  "books" : "吶喊,彷徨" }}

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

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" : "錢(qián)鐘書(shū)", "value" : {  "author" : "錢(qián)鐘書(shū)",  "books" : "宋詩(shī)選注,--haha--,談藝錄",  "sang" : "haha" }}{ "_id" : "魯迅", "value" : {  "author" : "魯迅",  "books" : "吶喊,--haha--,彷徨",  "sang" : "haha" }}

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

總結(jié)

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

參考資料:

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

2.mongodb mapreduce小試

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

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
蜜桃视频在线观看www社区| a视频网址在线观看| а√天堂中文资源在线bt| 婷婷激情小说网| 国精产品一区一区三区有限在线| 亚洲va欧美va国产综合久久| 国产精品久久久久久妇女| 九九九九精品九九九九| 乱妇乱女熟妇熟女网站| 伊人久久大香线蕉午夜av| 欧美久久香蕉| 开心色怡人综合网站| 孩xxxx性bbbb欧美| 免费在线观看日韩| 国产成人禁片免费观看| 少妇一级淫免费观看| 欧美 日韩 国产 一区二区三区| 天天摸天天操天天干| 日本福利片免费看| 精品人妻一区二区三区蜜桃视频| 国产成人麻豆精品午夜在线| 成人欧美一区二区三区视频网页| 国产精品视频你懂的| 91色在线视频| 亚洲精品久久久久中文字幕二区| 中文字幕第69页| 日批免费观看视频| japan高清日本乱xxxxx| 成人免费网站入口| 成人av影视| 欧美另类高清videos的特点| 国产精品久久久久久久久粉嫩av| 日本一区二区欧美| 欧美做受高潮6| 中国丰满人妻videoshd| 秋霞一区二区三区| 日本1区2区3区视频| 亚洲国产日韩精品| 黄网在线观看网址入口| 99久久婷婷这里只有精品| 欧美专区中文字幕| 欧美在线视频第一页| 在线观看av一区二区| 九九久久电影| 日韩一区二区在线视频| 91蝌蚪|人| 精品免费国产| 久久久久蜜桃| 国产精品传媒视频| 久久99青青精品免费观看| 91九色精品国产一区二区| 成人一区二区不卡免费| 一区二区高清不卡| 亚洲理论片在线观看| 女人在下体塞跳蛋在线观看| 99精品视频免费版的特色功能| 国产精品免费人成网站酒店| 免费的毛片视频| 色综合久久久无码中文字幕波多| 人人妻人人澡人人爽人人精品| 一区二区日韩视频| 在线观看你懂得| 妺妺窝人体色www聚色窝仙踪| 国产精品久久毛片| 国产精品丝袜在线| 久久99国产成人小视频| 成年人看的羞羞网站| 69xxxx国产| 国产女人18毛片水18精品| 久久精品久久精品国产大片| 男人天堂视频网| 裸体一区二区三区| 精品在线播放| 777视频在线观看| 国产福利91精品| 国产又粗又大又爽视频| av中文字幕在线免费观看| 日韩精品三级| 天天干天天操天天爽| 999这里只有精品| 欧美专区在线观看| 黄色网址在线免费| 性一交一乱一色一免费无遮挡| 亚洲深夜视频| 欧美性大战久久久| 小说区视频区图片区| 国产欧美日韩精品一区| 国产精品色哟哟网站| 亚洲人成免费电影| 天堂av一区二区三区| 精品一区二区三区免费视频| 免费三片在线播放| 成人福利片在线| 九色在线观看| 国产日韩在线不卡| 九九视频直播综合网| 日本一区二区在线免费观看| 国产免费无遮挡吸奶头视频| 欧美一区二区三区成人片在线| 一区二区在线观看视频| 国产麻豆剧果冻传媒视频杜鹃| 久久国产精品波多野结衣| 亚洲第一图区| 国产精品美女毛片真酒店| 性欧美16一18| 四虎国产成人免费观看| 天天干天天色综合| 理论电影国产精品| 久久久久久久久久福利| 国产欧美大片| 大陆精大陆国产国语精品| 亚洲精品国产美女| 亚洲一级av无码毛片精品| 亚洲视频天天射| 国产精品88久久久久久| 成人午夜精品一区二区三区| 国产日韩欧美在线观看视频| 欧美wwwxxxx| 国产手机视频在线观看| 天堂免费在线视频| 成人在线播放网站| 一卡二卡三卡日韩欧美| 成人av二区| 最猛黑人系列在线播放| 野外性xxxxfreexxxxx欧美| 日本不卡免费播放| 国产浮力第一页| 国产精品爽爽爽爽爽爽在线观看| jizzjizzjizzjizz日本| 操你啦在线视频| 国产一线在线观看| 天堂av在线免费| 91网站在线观看视频| 亚洲毛片一区二区| 精品制服美女久久| 制服丝袜中文字幕一区| 在线国产情侣| 日本h片久久| 成人av片网址| 四虎视频在线精品免费网址| jizzjizzjizz欧美| 在线播放日韩精品| 黄视频免费在线看| 国产精品黄色在线观看| 国产成人久久精品77777| 看电影就来5566av视频在线播放| 国产精品久久久久久搜索| 国产清纯白嫩初高中在线观看性色| 天天av综合网| 亚洲欧美日本免费| 国产精品igao视频网网址不卡日韩| 中文字幕欧美亚洲| 亚洲男人天堂2019| 免费在线观看你懂的| 国产aⅴ爽av久久久久成人| 精品久久人人做人人爱| 国产中文一区| 9l视频自拍9l视频自拍| 亚洲人午夜精品天堂一二香蕉| 亚洲淫成人影院| 中文字幕亚洲日本岛国片| 黄色欧美视频| zzjj国产精品一区二区| 欧美精品系列| 夜级特黄日本大片_在线| 欧美日韩综合一区| 国产日韩欧美视频| 97人洗澡人人免费公开视频碰碰碰| 人妻无码久久一区二区三区免费| 欧美在线精品一区二区三区| 亚洲精品91天天久久人人| 91免费在线播放| 欧美人交a欧美精品| 在线看日韩精品电影| 欧美精品www在线观看| 成人性生交大片| 97香蕉碰碰人妻国产欧美| 国产精品国产三级在线观看| 日本一道本久久| 色大18成网站www在线观看| 国产一区二区伦理片| 国产女精品视频网站免费| 色撸撸在线观看| 国产69精品久久久久按摩| 密臀av一区二区三区| 在线观看三级视频欧美| 老司机午夜性大片| 亚洲精品一区久久久久久| 超碰在线caoporen| 成人在线视频免费播放| 日韩欧美网站| 亚洲午夜性刺激影院| 再深点灬舒服灬太大了添少妇视频| 大色综合视频网站在线播放| 欧美尿孔扩张虐视频| 久久久无码人妻精品一区| 超碰在线公开超碰在线| 欧美黄网站色视频| 国产日韩欧美精品一区二区三区| 国产精品嫩草影院久久久| 四季av一区二区凹凸精品| 老色鬼久久亚洲一区二区| 老女人性生活视频| 日本一区二区三区在线免费观看| www国产亚洲精品久久网站| 91精品国产91久久久久久一区二区| 亚洲精品www久久久久久广东| 亚洲永久免费观看| 亚洲综合最新在线| av一区在线播放| 成人免费高清视频在线观看| 久热精品视频在线播放| 欧美一级欧美一级| 国产美女视频免费| 男人的天堂视频在线| 亚洲精品亚洲人成人网在线播放| 国产福利一区二区三区视频| 精品无人乱码一区二区三区| 国产精一品亚洲二区在线视频| 波多野结衣av无码| www.5588.com毛片| 国产综合无码一区二区色蜜蜜| 日韩精品在线影院| 亚洲人妖av一区二区| 99九九电视剧免费观看| 91美女视频网站| 精品国产欧美日韩不卡在线观看| 久久福利免费视频| 亚洲精品国产电影| 天天摸天天操天天爽| 欧美性欧美巨大黑白大战| 国产精品白丝jk黑袜喷水| 一本色道69色精品综合久久| 精品一成人岛国片在线观看| 国产精品美女久久久久久2018| 黄色片在线观看网站| 亚洲丝袜精品| 成人欧美一区二区三区黑人一| 黄色网在线看| 成年人视频网站免费| 午夜电影一区二区三区| 精品成人一区二区三区四区| 欧美精品三级在线| 国产综合网站| 美女网站免费观看| 风间由美中文字幕在线看视频国产欧美| 欧美成在线观看| 欧美三级在线免费观看| 超碰97av在线| 日韩一区二区三区免费视频| 国产成人一级片| 亚洲av无码一区东京热久久| 欧美 日韩 国产在线| 久久天天躁日日躁| 久久riav二区三区| 国产欧美一区二区视频| 91视频免费在线观看| 欧美成人一区二区| 亚洲高清毛片一区二区| 国产又黄又猛又粗| 精品福利一区二区三区免费视频| 欧美日韩三级电影在线| 日韩伦理在线| 亚洲成av人片在线观看www| 最近2018中文字幕免费在线视频| 又色又爽又高潮免费视频国产| 91在线高清免费观看| 欧美一二三四区在线| 欧美在线视频一区| 国产麻豆视频一区二区| 99麻豆久久久国产精品免费| 中文字幕一区日韩电影| 欧美va久久久噜噜噜久久| 日本成人超碰在线观看| 国产裸体美女永久免费无遮挡| 波多野结衣国产精品| 免费看黄色一级大片| 日韩精品dvd| 国产成人精品自拍| 综合激情国产一区| 国产在线视频综合| 激情综合婷婷| 国产美女精品视频| 图片区小说区国产精品视频| 丰满少妇一区二区三区专区| 91高清视频| 91九色国产ts另类人妖| 精品国产乱码久久久久久果冻传媒| 日韩制服一区| 91亚洲va在线va天堂va国| 99riav视频在线观看| 中文字幕一区不卡| 精品一二三区视频| 色av成人天堂桃色av| 日韩欧美国产综合在线| 欧美第一淫aaasss性| 小黄鸭精品aⅴ导航网站入口| 丝袜理论片在线观看| 国产激情一区二区三区四区| 亚洲色图av在线| 亚洲一区二区三区在线看| 外国成人免费视频| 日本中文字幕不卡免费| 一级黄色a毛片| bl动漫在线观看| av永久不卡| 国外av在线| 蜜桃狠狠色伊人亚洲综合网站| 久久精品视频在线观看免费| 中文成人综合网| 日韩在线一区二区三区四区| 黄色片网站免费| 黄页网站在线观看| 韩国三级丰满少妇高潮| 国产精品第一页第二页第三页| 日本一区二区三区久久久久久久久不| 亚洲国产精品视频一区| 女人高潮特级毛片| 国产欧美日韩综合精品一区二区三区| xxxx日本少妇| 青青草原国产在线视频| 久久久精品麻豆| 可播放的18gay1069| 日韩av毛片网| 欧美高清视频在线观看| 麻豆视频免费网站| 国产精品黄页网站在线播放免费| 中文字幕一区二区精品|