2012-04-23 12 views
15

tratar de agrupar por fecha y númeromapa mongodb reducir para conseguir visitantes únicos por fecha/día

mi documento

{ "_id" : ObjectId("4f956dee76ddb26752026e8f"), "request" : "default", "options" : "1", "keyword" : "somekey", "number" : "5b234b79-4d70-437e-8eef-32a2941af40a", "date" : "20120423200446", "time" : 1335193066 } 

mi consulta

map = "function() { var date = new Date(this.time * 1000); var key = date.getFullYear() + date.getMonth() + date.getDate(); emit({day : key, number: this.number}, {count: 1}); }" 

reduce = "function(key, values) { var count = 0; values.forEach(function(v) { count += v['count']; }); return {count: count}; }" 

db.txtweb.mapReduce(map, reduce, {out: "pageview_results"}); 

mi error

uncaught exception: map reduce failed:{ "errmsg" : "ns doesn't exist", "ok" : 0 } 

No puedo entender cuál es wron g, pero creo que es hacer algo con la funcionalidad de fecha.

Cualquier idea.

Respuesta

27

ns doesn't exist significa que está accediendo a una base de datos o una colección inexistente. Compruebe sus nombres

siguiente script grupo this.amount por día (sin tiempo)

 db.payments.mapReduce(
      function() { 
       var k = new Date(this.payment_time); 
       k.setMinutes(0); 
       k.setSeconds(0); 
       k.setMilliseconds(0); 
       emit(k, this.amount); 
      }, 
      function (key, vals) { 
       var total = 0; 
       for (var i = 0; i < vals.length; i++) { 
        total += vals[i]; 
       } 
       return total; 
      }, 
      { 
       out : {merge : "resultName" } 
      } 
    ); 
    } 
}; 
+0

ns no existe significa que está accediendo a una base de datos o colección no existente. Comprueba sus nombres ... Este fue el problema. Gracias – Anand

+0

Aparece el siguiente error cuando trato de ejecutarlo en el error nodejs: MongoError: excepción: la invocación del mapa ha fallado: JS Error: ReferenceError: clon no está definido nofile_b: 1 – peter

+0

Sí. El clon se usa para evitar la modificación del objeto de fecha original. Me salté la implementación de la función de clonación. Puede usar esto en su lugar - nueva Fecha (this.getTime()); – Anton

5

Esto sucede sobre todo cuando se ejecuta un guión y olvidado para seleccionar la base de datos

use your_database_name; 

Nota la línea para seleccionar la base de datos.

Cuestiones relacionadas