Mongoose update'不能使用part(..)来遍历元素

时间:2015-06-20 17:29:40

标签: node.js mongodb mongoose

我有这个非常烦人的问题,我无法使用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
}

2 个答案:

答案 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