我有这个非常烦人的问题,我无法使用mongoose更新任何内容。使用它真的很令人沮丧,而且文档根本没有帮助。
我有这个架构:
var userSchema = mongoose.Schema({
local : {
email : String,
password : String,
},
devices : [{
id : String,
name : String
}]
});
这是我想要将设备添加到数组devices
的代码:
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: []})' }
我没有找到解释为什么会发生这种情况的原因。我必须提到该文档(数据库中只有一个文档),就是这个:
{
"_id": {
"$oid": "5585a196fe11b21100635c74"
},
"devices": [],
"local": {
"password": "$2a$10$7hXVHw7izcYlqbD6xe/te.0w2zucZ7lA007g9kXdoIMPhZhRyCIru",
"email": "a@a.a"
},
"__v": 0
}
答案 0 :(得分:21)
尝试在更新中使用 positional $
operator ,该更新标识要更新的数组中的元素,而不显式指定数组中元素的位置,但这只会匹配一个元素一次:
User.update(
{
"local.email": user,
"devices.id": { "$ne": deviceID },
"devices.name": { "$ne": deviceName }
},
{
"$set": {
"devices.$.id": deviceID,
"devices.$.name": deviceName
}
}
);
从 docs ,位置$运算符充当与查询文档匹配的第一个元素的占位符,并且数组字段必须作为查询文档的一部分出现,因此查询文件
"devices.id": { "$ne": deviceID },
"devices.name": { "$ne": deviceName }
包含device
数组,并且会匹配device
数组id
不等于deviceID
且名称与您的名称不同的文档正在尝试更新。这甚至会匹配device
数组为空的文档。
答案 1 :(得分:8)
使用$ push或其他数组更新运算符向数组添加元素。有关详细信息,请参阅http://docs.mongodb.org/manual/reference/operator/update/push/#up._S_push