sql >> Database >  >> NoSQL >> MongoDB

Mongodb:verzamel array van gehele getallen voor elke arraypositie

Ik denk dat je hiervoor kaartreductie nodig hebt, om een ​​functie te schrijven die toegang heeft tot specifieke posities in de array. Je zou zoiets als dit kunnen proberen:

Kaartfunctie:

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

Verminder functie:

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;     
}

U kunt dan de volgende mapReduce-functie op uw verzameling uitvoeren:

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

En dat zou je het volgende gewenste resultaat moeten geven!

{
"_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. MongoDB - Toevoegen aan een set en verhogen

  2. Documentwaarde afdrukken in mongodb-shell

  3. Redis instellen op Webfaction

  4. Hoe een Order of Sort specificeren met behulp van het C#-stuurprogramma voor MongoDB?