我有一个非常烦人的问题,我无法使用 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: '不能使用部分(devices.id的设备)来遍历元素({devices: []})' }
我没有设法解释为什么会发生这种情况。不得不提的是文档(数据库中几乎只有一个文档),是这个:
{
"_id": {
"$oid": "5585a196fe11b21100635c74"
},
"devices": [],
"local": {
"password": "$2a$10$7hXVHw7izcYlqbD6xe/te.0w2zucZ7lA007g9kXdoIMPhZhRyCIru",
"email": "a@a.a"
},
"__v": 0
}
最佳答案
尝试使用 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
数组为空的文档。
关于node.js - Mongoose update '不能使用部分(..)来遍历元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30956959/