mongoose更新'不能使用部分(..)来遍历元素

我有这个非常恼人的问题,我不能使用mongoose更新任何东西。 使用真的令人沮丧,文档根本没有帮助。

我有这个模式:

var userSchema = mongoose.Schema({ local : { email : String, password : String, }, devices : [{ id : String, name : String }] }); 

这是我想要添加设备到arraysdevices

 function updateDeviceList(user, deviceID, deviceName) { User.update({ 'local.email' : user}, { $set: {'devices.id' : deviceID, 'devices.name' : deviceName}}, function(err, response) { if(err) { console.log("Update device error", err); } else { console.log("Update device OK"); } }); } 

在这一点上,我得到的错误: errmsg: 'cannot use the part (devices of devices.id) to traverse the element ({devices: []})' }

我无法find解释为什么会发生这种情况。 我不得不提到文档(数据库中几乎只有一个文档),是这样的:

 { "_id": { "$oid": "5585a196fe11b21100635c74" }, "devices": [], "local": { "password": "$2a$10$7hXVHw7izcYlqbD6xe/te.0w2zucZ7lA007g9kXdoIMPhZhRyCIru", "email": "a@aa" }, "__v": 0 } 

使用$ push或其他数组更新操作符将元素添加到数组中。 有关详细信息,请参阅http://docs.mongodb.org/manual/reference/operator/update/push/#up._S_push

尝试在更新中使用位置$运算符 ,该运算符标识数组中元素的更新,而不显式指定数组中元素的位置,但是这样只会一次匹配一个元素:

  User.update( { "local.email": user, "devices.id": { "$ne": deviceID }, "devices.name": { "$ne": deviceName } }, { "$set": { "devices.$.id": deviceID, "devices.$.name": deviceName } } ); 

文档中 ,位置$运算符充当匹配查询文档的第一个元素的占位符,并且数组字段必须作为查询文档的一部分出现,因此查询文档

 "devices.id": { "$ne": deviceID }, "devices.name": { "$ne": deviceName } 

包含device数组,并将匹配device数组id不等于deviceID且名称与您尝试更新的名称不同的那些文档。 这甚至会匹配device数组为空的文档。