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
数组为空的文档。