Cookies help us deliver our services. By using our services, you agree to our use of cookies. More information

MAPREDUCE Tutorial

From NoSQLZoo
Revision as of 10:46, 4 December 2015 by Andr3w (talk | contribs) (Created page with "==MapReduce the basics== <p>This tutorial introduces the <code>MapReduce</code> command.</p> MapReduce examples are available. <div>The MapReduce function allows to func...")
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to: navigation, search

MapReduce the basics

This tutorial introduces the MapReduce command.

MapReduce examples are available.

The MapReduce function allows to functions to be applied over a collection. The two functions map and reduce are important because:
  • Together they can solve a huge range of common database queries
  • They can be distributed effectively; you can share the work load among a number of processors and get your answer faster

Map

The map function can be used to filter and transform the data:

Use a map function to get the countries of Europe

db.world.mapReduce(
  function(){if (this.continent=="Europe") emit(this.name,null);},
  {out:{inline:1}}  
)

db.world.mapReduce(

 function(){if (this.continent=="Europe") emit(this.name,null);},
 {out:{inline:1}}  

)

Use the previous answer to find the population of the world to the nearest million

Use the JavaScript round function : Math.round(population/1000000)*1000000

from bson.code import Code temp = db.world.map_reduce(

   map=Code("function(){emit('World Population in Millions', this.population)}"),
   reduce=Code("""function(key, values){
     return Math.round(Array.sum(values)/1000000)*1000000;
   }"""),
   out={"inline":1})

pp.pprint(temp["results"])

Count number of countries by first letter


from bson.code import Code temp = db.world.map_reduce(

   map=Code("""function(){ emit((this.name).substring(0,1), 1)}"""),
   reduce=Code("""function(key, values){
      return Array.sum(values);
   }"""),
   out={"inline":1})

pp.pprint(temp["results"])

Show the number of countries on each continent


from bson.code import Code temp = db.world.map_reduce(

   map=Code("function(){emit(this.continent, 1)}"),
   reduce=Code("""function(key, values){
     return Array.sum(values);
   }"""),
   out={"inline":1})

pp.pprint(temp["results"])

Show the smallest 3 countries name and area (ignore areas of 0 or None)


from bson.code import Code temp = db.world.map_reduce(

       query={"$and":[{"area":{"$ne":None}}, {"area":{"$ne":0}}]},
       sort={"area":1},
       limit=3,
       map=Code("function(){emit(this.name, this.area)}"), 
       reduce=Code("function(key, values){}"),
       out={"inline":1},

)

pp.pprint(

  temp["results"]

)

Return the first and last country based on name order for each continent


from bson.code import Code temp = db.world.map_reduce(

   map=Code("function(){emit(this.continent, {first:this.name,last:this.name})}"),
   reduce=Code("""function(key, values){
     var ret = {first:'ZZZ',last:'AAA'};
     for(var i=0;i<values.length;i++){
       if (ret.first>values[i].first) ret.first=values[i].first;
       if (ret.last<values[i].last) ret.last=values[i].last;
     }
     return ret;
   }"""),
   out={"inline":1})

pp.pprint(temp["results"])

Return country name or capital city that starts with a letter 'M'


from bson.code import Code temp = db.world.map_reduce(

   map=Code("""function(){ 
                if((this.name).startsWith('M')) 
                     emit(this.name,null);
                if((this.capital).startsWith('M')) 
                  emit(this.capital,null);
            }"""),
   reduce=Code("""function(key, values){
      return values;
   }"""),
   
   out={"inline":1})

pp.pprint(temp["results"])

Show the first and last city for each letter and the count of cities


from bson.code import Code temp = db.world.map_reduce(

   map=Code("""function(){ if(this.capital)emit((this.capital).substring(0,1), {first:this.capital, last:this.capital})}"""),
   reduce=Code("""function(key, values){
      var ret = {first:'ZZZ',last:'AAA', count:0};
     for(var i=0;i<values.length;i++){
       if (ret.first>values[i].first) ret.first=values[i].first;
       if (ret.last<values[i].last) ret.last=values[i].last;
       ret.count += 1;
     }
     return ret;
   }"""),
   finalize=Code("""function(key, val){
     if(!val.count){
        val.count = 1;
        return val;
     }else
        return val;
   }"""),
   out={"inline":1})

pp.pprint(temp["results"])

Show country count for countries in the ranges

 0 to 1000000
 1000000 to 2000000
 2000000 to 3000000
 3000000 to 5000000
 5000000 to 10000000
 10000000 to 15000000
 More than 15000000  

from bson.code import Code temp = db.world.map_reduce(

   map=Code("""function(){
                 var pop = this.population;
                 switch(true){
                   case pop<1000000:
                      emit("0 TO 1000000", 1);
                      break;
                   case pop<2000000:
                      emit("1000000 TO 2000000", 1);
                      break;
                   case pop<3000000:
                      emit("2000000 TO 3000000", 1);
                      break;
                   case pop<5000000:
                      emit("3000000 TO 5000000", 1);
                      break;
                   case pop<10000000:
                      emit("5000000 TO 10000000", 1);
                      break;
                   case pop<15000000:
                      emit("10000000 TO 15000000", 1);
                      break
                   case pop>15000000:
                      emit("MORE THAN 15000000", 1);
                      break;
                 }
}"""),
   reduce=Code("""function(key, values){ return Array.sum(values); }"""),      
   out={"inline":1})

pp.pprint(temp["results"])