{"id":652,"date":"2012-03-23T13:24:17","date_gmt":"2012-03-23T05:24:17","guid":{"rendered":"https:\/\/yanjingang.com\/blog\/?p=652"},"modified":"2016-03-10T13:24:52","modified_gmt":"2016-03-10T05:24:52","slug":"mongodb-group-by-mapreduce","status":"publish","type":"post","link":"https:\/\/yanjingang.com\/blog\/?p=652","title":{"rendered":"mongodb group by mapreduce"},"content":{"rendered":"<p>\u65b0\u5efa<span lang=\"EN-US\">collection <\/span>\u540d\u79f0<span lang=\"EN-US\">\u00a0\u00a0\u00a0test <\/span>\uff0c\u8868\u4e2d\u7684\u5185\u5bb9<span lang=\"EN-US\"><br \/>\nmongos&gt; db.test.find();<br \/>\n{ &#8220;_id&#8221; : ObjectId(&#8220;4ee7125f0f3210cf35a32f02&#8243;),&#8221;name&#8221; : &#8220;xm01&#8221;, &#8220;age&#8221; : 10 }<br \/>\n{ &#8220;_id&#8221; : ObjectId(&#8220;4ee712a80f3210cf35a32f03&#8243;),&#8221;name&#8221; : &#8220;xm02&#8221;, &#8220;age&#8221; : 20 }<br \/>\n{ &#8220;_id&#8221; : ObjectId(&#8220;4ee712c60f3210cf35a32f04&#8243;),&#8221;name&#8221; : &#8220;xm01&#8221;, &#8220;age&#8221; : 30 }<br \/>\n{ &#8220;_id&#8221; : ObjectId(&#8220;4ee712d20f3210cf35a32f05&#8243;),&#8221;name&#8221; : &#8220;xm02&#8221;, &#8220;age&#8221; : 20 }<br \/>\n{ &#8220;_id&#8221; : ObjectId(&#8220;4ee712d70f3210cf35a32f06&#8243;),&#8221;name&#8221; : &#8220;xm03&#8221;, &#8220;age&#8221; : 20 }<br \/>\n{ &#8220;_id&#8221; : ObjectId(&#8220;4ee7173d0f3210cf35a32f07&#8243;),&#8221;name&#8221; : &#8220;xm02&#8221;, &#8220;age&#8221; : 10 }<\/p>\n<p><\/span>\u4e0b\u9762\u5bf9<span lang=\"EN-US\">name<\/span>\u505a<span lang=\"EN-US\">group by ,<\/span>\u5bf9<span lang=\"EN-US\">age<\/span>\u505a\u6c47\u603b<span lang=\"EN-US\"><br \/>\n<\/span>\u5b9a\u4e49<span lang=\"EN-US\"> map<\/span>\u51fd\u6570<span lang=\"EN-US\"><br \/>\nm=function(){emit(this.name,{age:this.age})}; \/\/<\/span>\u7edf\u8ba1<span lang=\"EN-US\">name<\/span>\u6b21\u6570\uff1a<span lang=\"EN-US\">emit(this.name,{cnt:1})<br \/>\n<\/span>\u5b9a\u4e49<span lang=\"EN-US\">reduce<\/span>\u51fd\u6570<span lang=\"EN-US\"><br \/>\nr=function(key,values){var result={age:0}; values.forEach(function(v){result.age +=v.age; } ); return result};<br \/>\n<\/span>\u8c03\u7528<span lang=\"EN-US\">mapreduce<\/span>\u6267\u884c<span lang=\"EN-US\">group by<\/span>\u67e5\u8be2<span lang=\"EN-US\"><br \/>\nmongos&gt; db.runCommand({<br \/>\n&#8230; mapreduce:&#8221;test&#8221;,\u00a0\u00a0\u00a0\u00a0 \/\/<\/span>\u6267\u884c\u5206\u7ec4\u7684\u96c6\u5408<span lang=\"EN-US\"><br \/>\n&#8230;map:m,\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\/\/map<\/span>\u51fd\u6570\uff0c\u5faa\u73af\u96c6\u5408\u5bf9\u8c61<span lang=\"EN-US\"><br \/>\n&#8230;reduce:r,\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\/\/reduce<\/span>\u51fd\u6570\uff0c\u5bf9<span lang=\"EN-US\">document<\/span>\u505a\u6c47\u603b<span lang=\"EN-US\"><br \/>\n&#8230;out:&#8221;res&#8221;\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\/\/<\/span>\u8f93\u51fa\u7ed3\u679c<span lang=\"EN-US\"><br \/>\n&#8230; })<br \/>\n<\/span>\u7ed3\u679c\u663e\u793a\uff1a<span lang=\"EN-US\"><br \/>\ndb.res.find();<br \/>\nmongos&gt; db.res.find();<br \/>\n{ &#8220;_id&#8221; : &#8220;xm01&#8221;, &#8220;value&#8221; : { &#8220;count&#8221; :2, &#8220;age&#8221; : 40 } }<br \/>\n{ &#8220;_id&#8221; : &#8220;xm02&#8221;, &#8220;value&#8221; : { &#8220;count&#8221; :3, &#8220;age&#8221; : 50 } }<br \/>\n{ &#8220;_id&#8221; : &#8220;xm03&#8221;, &#8220;value&#8221; : { &#8220;count&#8221; :1, &#8220;age&#8221; : 20 } }<\/span><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u65b0\u5efacollection \u540d\u79f0\u00a0\u00a0\u00a0test \uff0c\u8868\u4e2d\u7684\u5185\u5bb9 mongos&gt; db.test.find() [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":[],"categories":[21],"tags":[338,22],"_links":{"self":[{"href":"https:\/\/yanjingang.com\/blog\/index.php?rest_route=\/wp\/v2\/posts\/652"}],"collection":[{"href":"https:\/\/yanjingang.com\/blog\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/yanjingang.com\/blog\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/yanjingang.com\/blog\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/yanjingang.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=652"}],"version-history":[{"count":0,"href":"https:\/\/yanjingang.com\/blog\/index.php?rest_route=\/wp\/v2\/posts\/652\/revisions"}],"wp:attachment":[{"href":"https:\/\/yanjingang.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=652"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/yanjingang.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=652"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/yanjingang.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=652"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}