NodeJS и MongoDB FindAndModify () необходимо удалить или обновить

Я пытаюсь сделать findAndModifiy в mongodb с nodejS, это мой код:

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

EDIT:

попробуйте с обратным вызовом

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

но дайте мне ошибку, которую нужно удалить или обновить..Но я делаю это..

4 ответов


на .findAndModify() метод в реализации собственного драйвера узла отличается от реализации оболочки mongo. Чтобы сделать обновление, как указано выше:

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

   }
);

как ни странно, чтобы удалить вы указываете в настройках так же "удалить" соответствующий документ:

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

   }
);

основное отличие в том, что вы не называете "ключевые" разделы для действий.


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

этот документ выше указывает, что второй параметр является порядком сортировки для выбора документа, если несколько из них соответствуют запросу. Только предоставление двух параметров приведет к сообщению об ошибке" нужно удалить или обновить".

collection('MyCollection').findAndModify(
    { _id: "auto" },
    [],
    { $inc: { "bill": 1 } },
    { upsert: true, new: true },
    function(err,doc) {
       // work here
    }
);

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

попробуйте это сработало для меня в nodejs

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

    })