sql >> Databasteknik >  >> NoSQL >> MongoDB

Mongoose - Öka ett värde inuti en array av objekt

Det är inte möjligt att direkt öka värdet i .find fråga om labelOptions är en array av objekt. För att göra det enklare bör du ändra labelOptions typ från Array of Objects till Object:

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

Överväg också att använda .findByIdAndUpdate istället för .findOneAndUpdate om du frågar efter dokumentets _id . Och sedan kan du uppnå vad du vill genom att:

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

UPPDATERING:Om du är ihärdig med att använda Array of Objects för labelOptions , det finns 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. MongoDB:s sammanlagda räkning är för långsam

  2. Redis som en databas

  3. Ska jag komma åt mongodb direkt?

  4. Hur man sorterar en samling med det sista elementet i en array