【问题标题】:Update of multiple documents with mongoose fails使用 mongoose 更新多个文档失败
【发布时间】:2016-02-25 21:22:28
【问题描述】:

我尝试使用 mongoose (3.8.37) 更新多个文档,但没有更新任何文档。

我已经完成了从其他问题中学到的所有事情(见下文):

  • 使用回调函数
  • 指定multi: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

那么错误在哪里?

关于这个话题有几个问题。不幸的是,这些都不能解决我的问题。

** 更新

added a log callback 发现只要指定了选项 (multi:true),就不会执行对 mongodb 的查询。

【问题讨论】:

  • 尝试将您的.update({deleted:1},... 更改为.update({ $set: { deleted:1}},{multi: true}, function...
  • @Molda 感谢您的提示。但我已经尝试过了。没有帮助。

标签: node.js mongoose


【解决方案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);
    });
}

【讨论】:

  • 太棒了!有效:User.where().update() 无效:User.where().update(multi:true) => 结论:总是按照 Molda 的建议使用 User.update()!
猜你喜欢
  • 2013-08-14
  • 2015-02-19
  • 1970-01-01
  • 2020-04-20
  • 1970-01-01
  • 2017-12-08
  • 2017-09-22
  • 1970-01-01
  • 2019-12-09
相关资源
最近更新 更多