婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

MongoDB中MapReduce的使用方法詳解

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

前言

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

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

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

這導致的問題就是在reduce中 如果 初始化 var count = 0;在循環中 count ++,最后輸出的是1???

避免都方法是,把數據存在返回的value里,這個value是會在循環進入reduce的時候重用的。在循環中 count += value.count就能把之前都100加上了!!!

還有如果只有一條數據,那它不會進入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可以用來實現更復雜的聚合命令,使用MapReduce主要實現兩個函數:map函數和reduce函數,map函數用來生成鍵值對序列,map函數的結果作為reduce函數的參數,reduce函數中再做進一步的統計,比如我的數據集如下:

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

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

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函數主要用來實現分組,接收兩個參數,第一個參數表示分組的字段,第二個參數表示要統計的數據,reduce來做具體的數據處理操作,接收兩個參數,對應emit方法的兩個參數,這里使用了Array中的sum函數對price字段進行自加處理,options中定義了將結果輸出的集合,屆時我們將在這個集合中去查詢數據,默認情況下,這個集合即使在數據庫重啟后也會保留,并且保留集合中的數據。

查詢結果如下:

{
 "_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()

查詢結果如下:

{
 "_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()

結果如下:

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

比如查詢每個人售價在¥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表示對查到的集合再進行篩選。

結果如下:

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

runCommand實現

我們也可以利用runCommand命令來執行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>
    }
    )

含義如下:

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

如下操作,表示執行MapReduce操作并對統計的集合限制返回條數,限制返回條數之后再進行統計操作,如下:

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()

執行結果如下:

{
 "_id" : "曹雪芹",
 "value" : "紅樓夢"
}
{
 "_id" : "錢鐘書",
 "value" : "宋詩選注,談藝錄"
}
{
 "_id" : "魯迅",
 "value" : "吶喊"
}

小伙伴們看到,魯迅有一本書不見了,就是因為limit是先限制集合返回條數,然后再執行統計操作。

finalize操作表示最終處理函數,如下:

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第一個參數key表示emit中的第一個參數,第二個參數表示reduce的執行結果,我們可以在f1中對這個結果進行再處理,結果如下:

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

scope則可以用來定義一個在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()

執行結果如下:

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

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

總結

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

參考資料:

1.《MongoDB權威指南第2版》

2.mongodb mapreduce小試

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

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

標簽:遼陽 興安盟 雞西 自貢 泰安 廈門 玉林 無錫

巨人網絡通訊聲明:本文標題《MongoDB中MapReduce的使用方法詳解》,本文關鍵詞  MongoDB,中,MapReduce,的,使用方法,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MongoDB中MapReduce的使用方法詳解》相關的同類信息!
  • 本頁收集關于MongoDB中MapReduce的使用方法詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产在线播放一区| 激情综合五月天| 欧美日韩精品一区二区三区四区 | 911国产精品| 国产99久久久国产精品| 久久精品国产99| 亚洲成av人影院| 亚洲综合色丁香婷婷六月图片| 26uuu精品一区二区三区四区在线| eeuss影院一区二区三区| 国产一区二区网址| 精品一区二区综合| 热久久国产精品| 日本中文一区二区三区| 午夜成人在线视频| 天天操天天色综合| 日韩中文字幕1| 蜜臀av性久久久久蜜臀aⅴ流畅 | 日韩欧美的一区二区| 欧美美女网站色| 欧美午夜不卡在线观看免费| 91久久精品国产91性色tv | 国产永久精品大片wwwapp| 日本在线不卡视频一二三区| 无码av免费一区二区三区试看| 亚洲欧洲一区二区在线播放| 国产精品色一区二区三区| 国产精品欧美一区喷水| 亚洲欧洲日韩av| 亚洲黄色性网站| 亚洲国产你懂的| 久久国产免费看| 国产成人精品综合在线观看| 成人精品免费看| 色激情天天射综合网| 欧美日韩国产一区| 精品国产电影一区二区| 国产精品美女久久久久久久久| 国产精品美女久久久久久久久久久 | 99精品久久99久久久久| 国产精品亚洲成人| 国产成人自拍高清视频在线免费播放| 肉肉av福利一精品导航| 蜜臀av一区二区三区| 成人性色生活片免费看爆迷你毛片| 成人动漫中文字幕| 91麻豆精品国产无毒不卡在线观看| 日韩小视频在线观看专区| 国产精品五月天| 午夜亚洲福利老司机| 国产精品小仙女| 欧美私人免费视频| 国产校园另类小说区| 亚洲欧美激情一区二区| 欧美bbbbb| 色狠狠色狠狠综合| 日韩一区二区在线观看视频播放| 2022国产精品视频| 亚洲一区二区在线免费观看视频 | 本田岬高潮一区二区三区| 欧美亚男人的天堂| 久久久久久久综合狠狠综合| 亚洲一区二区三区中文字幕在线| 首页欧美精品中文字幕| 国产91精品一区二区麻豆网站 | 精品国产露脸精彩对白| 亚洲视频一二区| 精品夜夜嗨av一区二区三区| 在线免费观看视频一区| 久久女同精品一区二区| 天天综合色天天综合色h| 成人免费高清在线| 26uuu国产电影一区二区| 亚洲国产视频网站| 色综合久久久久综合99| 国产精品无码永久免费888| 狠狠色丁香婷婷综合久久片| 欧美日韩免费在线视频| 亚洲天堂成人在线观看| 国产成人精品1024| 精品久久久久久久人人人人传媒| 有坂深雪av一区二区精品| 国产91丝袜在线观看| 欧美va在线播放| 美女任你摸久久| 欧美一级片在线| 奇米影视一区二区三区小说| 欧美日韩久久一区二区| 一区二区三区久久久| 99久久久久免费精品国产 | 免费成人小视频| 欧美日韩高清一区二区| 亚洲电影在线免费观看| 色偷偷一区二区三区| 亚洲乱码中文字幕| 欧美视频精品在线| 亚洲一区二区欧美日韩 | 日韩二区三区四区| 欧美一区二区在线观看| 日本最新不卡在线| 精品国产一区二区三区不卡| 精品亚洲成a人在线观看| 日韩欧美久久一区| 国产在线不卡视频| 国产精品人妖ts系列视频| 国模冰冰炮一区二区| 精品久久久网站| 粉嫩嫩av羞羞动漫久久久 | 性做久久久久久免费观看欧美| 91色婷婷久久久久合中文| 亚洲女人的天堂| 91精品国产综合久久精品app | 国产网站一区二区三区| 国产白丝网站精品污在线入口| 精品国产自在久精品国产| 精品一区二区免费| 国产亚洲精久久久久久| 91丝袜美腿高跟国产极品老师| 亚洲少妇中出一区| 9191成人精品久久| 国产美女一区二区| 亚洲精品高清视频在线观看| 日韩一区二区在线观看视频播放| 狠狠色伊人亚洲综合成人| 国产精品网站一区| 91久久一区二区| 国产麻豆午夜三级精品| 亚洲国产日韩在线一区模特| 91精品国产色综合久久| 丁香六月久久综合狠狠色| 亚洲女女做受ⅹxx高潮| 8v天堂国产在线一区二区| 国产一区二区三区在线观看免费视频 | 亚洲综合一区在线| 色综合色狠狠综合色| 日韩福利电影在线| 国产精品情趣视频| 欧美一区二区三区四区久久| hitomi一区二区三区精品| 日本三级亚洲精品| 最新不卡av在线| 日韩欧美国产综合在线一区二区三区| 日韩av在线播放中文字幕| 国产精品乱人伦| 日韩亚洲欧美一区| 91国偷自产一区二区三区观看 | 91在线精品秘密一区二区| 日本成人在线视频网站| 亚洲欧洲av在线| 久久精品视频网| 日韩欧美精品三级| 欧美日韩aaa| 色狠狠av一区二区三区| 成人永久aaa| 韩国女主播一区| 日韩电影免费在线观看网站| 亚洲综合在线电影| 国产精品你懂的在线| 国产情人综合久久777777| 精品日韩av一区二区| 欧美日韩国产首页| 欧美三级一区二区| 欧美在线影院一区二区| 欧美在线观看视频一区二区| 色久综合一二码| 色综合中文字幕国产| 国产成人av影院| 国产一区二区在线观看视频| 狂野欧美性猛交blacked| 91精品久久久久久久久99蜜臂| 91在线你懂得| jlzzjlzz亚洲女人18| 成人免费视频app| 丁香六月综合激情| av网站免费线看精品| 成人爱爱电影网址| 不卡大黄网站免费看| 中文字幕亚洲区| 国产精品福利在线播放| 国产精品久久三区| 亚洲欧洲精品成人久久奇米网| 久久夜色精品一区| 国产日韩欧美一区二区三区乱码| 欧美大白屁股肥臀xxxxxx| 欧美一二三四区在线| 日韩欧美一级精品久久| 26uuu成人网一区二区三区| 国产喂奶挤奶一区二区三区| 欧美国产日韩亚洲一区| 18欧美乱大交hd1984| 亚洲综合在线五月| 日韩精品福利网| 国产一区二区三区在线观看免费视频| 午夜av电影一区| 精品中文av资源站在线观看| 国产精品一二二区| 日本中文字幕一区二区有限公司| 一二三四社区欧美黄| 三级成人在线视频| 国产自产v一区二区三区c|