sql >> Database teknologi >  >> NoSQL >> MongoDB

Mongoose - Forøg en værdi inde i en række objekter

Det er ikke muligt direkte at øge værdien i .find spørg hvis labelOptions er en række af objekter. For at gøre det nemmere bør du ændre labelOptions type fra Array of Objects til Object:

"labelOptions": {
    "Bob": 112,
    "Billy": 32,
    "Joe": 45
};

Overvej også at bruge .findByIdAndUpdate i stedet for .findOneAndUpdate hvis du forespørger efter dokumentets _id . Og så kan du opnå det, du ønsker, ved at:

Poll.findByIdAndUpdate(
    id,
    {$inc: {`labelOptions.${labelOption}`: 1 }},
    function(err, document) {
    console.log(err);
});

OPDATERING:Hvis du er vedholdende med at bruge Array of Objects til labelOptions , der er en løsning:

Poll.findById(
    id,
    function (err, _poll) {

        /** Temporarily store labelOptions in a new variable because we cannot directly modify the document */
        let _updatedLabelOptions = _poll.labelOptions;

        /** We need to iterate over the labelOptions array to check where Bob is */
        _updatedLabelOptions.forEach(function (_label) {

            /** Iterate over key,value of the current object */
           for (let _name in _label) {

               /** Make sure that the object really has a property _name */
               if (_label.hasOwnProperty(_name)) {

                   /** If name matches the person we want to increment, update it's value */
                   if (_name === labelOption) ++_label._name;
               }
           }
        });

        /** Update the documents labelOptions property with the temporary one we've created */
        _poll.update({labelOptions: _updatedLabelOptions}, function (err) {

            console.log(err);
        });
    });


  1. Sådan genbruger du mongodb-forbindelse gennem Promise

  2. MongoDB Regex, Index &Performance

  3. Sortering efter virtuelt felt i mongoDB (mongoose)

  4. Hvordan begrænser man antallet af underkolonne i MongoDB?