MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Mongodb:zagregowana tablica liczb całkowitych dla każdej pozycji tablicy

Myślę, że będziesz potrzebować do tego map Reduce, aby napisać funkcję, która może uzyskać dostęp do określonych pozycji w tablicy. Możesz spróbować czegoś takiego:

Funkcja mapowania:

var M = function() { 
    emit( this.agent, { score : this.score, qv : this.qv } )
}

Zmniejszenie funkcji:

var R = function(key, values) {
    var result = { score : [0, 0, 0], qv : [0, 0, 0, 0, 0] };
    values.forEach( function(value) {
        for ( var i = 0; i < value.score.length; i ++ ) {
            result.score[i] += parseInt(value.score[i]);
        }
        for ( var i = 0; i < value.qv.length; i ++ ) {
            result.qv[i] += parseInt(value.qv[i]);
        }
    });
    return result;     
}

Następnie możesz uruchomić w swojej kolekcji następującą funkcję mapReduce:

db.foo.mapReduce( M, R, { out : "resultCollection" } )

A to powinno dać ci następujący pożądany rezultat!

{
"_id" : "006",
"value" : {
    "score" : [2, 1, 0],
    "qv" : [ 3, 0, 3, 0, 2 ]
}
}
{
"_id" : "007",
"value" : {
    "score" : [ 1, 0, 0],
    "qv" : [ 1, 0, 1, 0, 0]
}

}




  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Jak zignorować wartości null podczas rozmieszczania dokumentu MongoDB?

  2. Sprawdź istnienie kolekcji w MongoDB

  3. Zwróć ostatnią prawdziwą wartość dla każdej grupy

  4. Białe znaki MongoDB

  5. Jak zaktualizować te konkretne dane w tej kolekcji użytkowników w mongodb?