web-dev-qa-db-fra.com

NodeJS et MongoDB FindAndModify () doivent être supprimés ou mis à jour.

im essayant de faire un findAndModifiy dans Mongodb avec nodejS, ceci est mon code:

var nextBill = function (db, success, log) {
    var collection = db.collection('autoincrements');
    log.debug('autoIncrementRepository', 'nextBill');
    var result = collection.findAndModify({
        query: { _id: 'auto' },
        update: { $inc: { bill: 1 } },
        new: true
    });

    success(result.bill);
};

MODIFIER:

Essayer avec callback

collection.findAndModify({
        query: { _id: 'auto' },
        update: { $inc: { bill: 1 } },
        new: true
    }, function (e, result) {
        success(result.budget);
    });

Mais donnez-moi le besoin de supprimer ou de mettre à jour..Mais je le fais ..

12
colymore

La méthode .findAndModify() dans l'implémentation du pilote natif du noeud est différente de l'implémentation du shell mongo. Pour faire une mise à jour comme ci-dessus, vous faites:

collection.findAndModify(
   { "_id": "auto" },
   { "$inc": { "bill": 1 } },
   function(err,doc) {
     // work here

   }
);

Bizarrement, il est assez difficile de supprimer les options que vous spécifiez pour que le même document "supprime" le document correspondant:

collection.findAndModify(
   { "_id": "auto" },
   { "$inc": { "bill": 1 } },
   { "remove": true },
   function(err,doc) {
     // work here

   }
);

La principale différence étant que vous ne nommez pas les sections "clés" des actions.

18
Neil Lunn

http://mongodb.github.io/node-mongodb-native/2.0/api/Collection.html#findAndModify

Ce document ci-dessus spécifie que le deuxième paramètre est l'ordre de tri permettant de choisir le document à utiliser si plusieurs d'entre eux correspondent à la requête. Si vous ne donnez que deux paramètres, le message d'erreur "besoin de supprimer ou de mettre à jour" sera généré.

collection('MyCollection').findAndModify(
    { _id: "auto" },
    [],
    { $inc: { "bill": 1 } },
    { upsert: true, new: true },
    function(err,doc) {
       // work here
    }
);
9
Paul Van Camp
Hi I have followed this and it worked perfectly.

db.collection('test').findAndModify(
  {hello: 'world'}, // query
  [['_id','asc']],  // sort order
  {$set: {hi: 'there'}}, // replacement, replaces only the field "hi"
  {}, // options
  function(err, object) {
      if (err){
          console.warn(err.message);  // returns error if no matching object found
      }else{
          console.dir(object);
      }
  });
});
2
vijesh mundayat

Essayez ceci Cela a fonctionné pour moi dans nodejs

users.findAndModify(
           { "_id": userid,"password":pwd},
           [['_id', 'asc']],
           { "$set":{"password":npwd}},
           {"upsert":false}
        ,function(err,result){
        //enter code here

    })
0
Veerakrishna P