1

我有这样的mongo结构:

{
        "_id" : ObjectId("51596b7e469b9c3816000001"),
        "company" : {
                "_id" : "ade2fd0ec9b8b5e9152e0155",
                "title" : "LO3426546457"
        },
}
{
        "_id" : ObjectId("51596cef469b9c3816000008"),
        "company" : {
                "_id" : "ade2fd0ec9b8b5e9152e0155",
                "title" : "LO3426546457"
        },
}
{
        "_id" : ObjectId("51596cc3469b9c3816000007"),
        "company" : {
                "_id" : "ade2fd0ec9b8b5e9152e0155",
                "title" : "LO3426546457"
        }        
}

我想更改具有特定“_id”的对象的所有“标题”字段。我喜欢这样:

Collections.UsersCollection.update({
    'company._id': 'ade2fd0ec9b8b5e9152e0155'
}, {
    $set: {
        'company': { _id: 'ade2fd0ec9b8b5e9152e0155', title: 'blablabla' }
        // I also tried: 'company.title': 'blablabla'
    }
}, false, true);

在 Node.js 中执行该代码后(我使用 node-mongodb-native),mongo只更新一个文档。

但是,如果我在 Mongo Shell (mongo.exe) 上执行该命令,一切正常并更新所有文档。

有什么问题?

4

2 回答 2

2

默认情况下,mongo 只更新一个文档。http://docs.mongodb.org/manual/reference/method/db.collection.update/

使用多选项进行多个文档更新。

于 2013-04-01T12:11:56.060 回答
0

默认情况下,collection.update() 只更新单个文档,如果您需要更新多个文档,则必须在回调函数之前添加 {multi:1} 参数。

于 2013-07-02T18:20:38.487 回答