Ede*_*eph 21 mongoose mongodb node.js
我有这个非常烦人的问题,我无法使用mongoose更新任何东西.使用它真的很令人沮丧,文档根本没有帮助.
我有这个架构:
var userSchema = mongoose.Schema({
local : {
email : String,
password : String,
},
devices : [{
id : String,
name : String
}]
});
Run Code Online (Sandbox Code Playgroud)
这是我想在数组中添加设备的代码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");
}
});
}
Run Code Online (Sandbox Code Playgroud)
此时我收到错误:
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
}
Run Code Online (Sandbox Code Playgroud)
chr*_*dam 22
尝试在更新中使用位置$运算符来标识要更新的数组中的元素,而不显式指定元素在数组中的位置,但这只会一次匹配一个元素:
User.update(
{
"local.email": user,
"devices.id": { "$ne": deviceID },
"devices.name": { "$ne": deviceName }
},
{
"$set": {
"devices.$.id": deviceID,
"devices.$.name": deviceName
}
}
);
Run Code Online (Sandbox Code Playgroud)
从文档中,位置$运算符充当与查询文档匹配的第一个元素的占位符,并且数组字段必须作为查询文档的一部分出现,因此查询文档
"devices.id": { "$ne": deviceID },
"devices.name": { "$ne": deviceName }
Run Code Online (Sandbox Code Playgroud)
包含device数组,并将匹配device数组id不相等的文档,deviceID并且名称与您尝试更新的名称不同.这甚至会匹配device数组为空的文档.
使用$ push或其他数组更新运算符将元素添加到数组中.有关详细信息,请参阅http://docs.mongodb.org/manual/reference/operator/update/push/#up._S_push
| 归档时间: |
|
| 查看次数: |
28449 次 |
| 最近记录: |