Обновление нескольких документов с помощью мангуста не удается

Я пытаюсь обновить несколько документов с помощью мангуста (3.8.37), но ни один документ не обновляется.

Я сделал все, что узнал из других вопросов (см. Ниже):

  • Используйте функцию обратного вызова
  • Укажите несколько: true

Мое заявление об обновлении:

    Animal.where({ type: type}).update({deleted:1}, { multi: true, overwrite: true }, function (err,doc) {
        console.log("updates: "+doc);
    });

обновления: 0

Когда я просто пересчитаю документы, я получу результат. => Запрос правильный

    Animal.where({type: type}).count(function (err,doc) {
        console.log("count: "+doc);
    });

количество: 299

Когда я опускаю параметр multi:true, обновляется первая запись. => Заявление об обновлении тоже верно

    Animal.where({ type: type}).update({deleted:-1}, function (err,doc) {
        console.log("updates: "+doc);
    });

обновления: 1

Так где ошибка?

Есть несколько вопросов по этой теме. К сожалению, ни один из них не решает мою проблему.

** ОБНОВИТЬ

Я добавил обратный вызов журнала и обнаружил, что запрос к mongodb не выполняется, пока указаны параметры (multi:true).


person Matthias M    schedule 23.11.2015    source источник
comment
Попробуйте изменить .update({deleted:1},... на .update({ $set: { deleted:1}},{multi: true}, function...   -  person Molda    schedule 23.11.2015
comment
@Молда Спасибо за подсказку. Но это я уже пробовал. Не помогло.   -  person Matthias M    schedule 23.11.2015


Ответы (1)


Я настроил небольшой пример, который работает, как и ожидалось, сначала я вызвал start(), чтобы создать несколько пользователей, затем update()

var mongoose = require('mongoose'); //v4.2.7

var userSchema = mongoose.Schema({
    deleted: Number,
    name: String
});

var User = mongoose.model('user', userSchema);

mongoose.connect('mongodb://127.0.0.1:27017/user');

//start();

function start(){

    for (var i = 0; i < 5; i++) {
        var user = new User({
            deleted: 1,
            name: i
        }); 
        user.save(); 
        console.log('user ---> ', user);      
    };

    User.find({}, function(err, docs){
        console.log('found ---> ', err, docs);
    });

}

update();

function update (){
    User.update({deleted:1}, {$set: {deleted: 0}}, {multi:true}, function(err, numAffected){
        console.log('updated ---> ', err, numAffected);
    });
}

Я не уверен, почему обновление не работает с where(...)

function update (){
    // this doesn't work
    User.where({deleted:1}).update({$set: {deleted: 0}}, {multi:true}, function(err, numAffected){
        console.log('updated ---> ', err, numAffected);
    });
}
person Molda    schedule 23.11.2015
comment
Здорово! Работает: User.where().update() Не работает: User.where().update(multi:true) => Вывод: всегда используйте User.update(), как предлагает Molda! - person Matthias M; 23.11.2015