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

РЕДАКТИРОВАТЬ:

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

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

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

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

    })
Другие вопросы по тегам