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

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

  • @Edeph由于您最初提到设备数组将为空,因此 **`$push`** 操作将起作用,但对于后续更新,您可能需要考虑 [**`findOneAndUpdate()`**](http:// /mongoosejs.com/docs/api.html#model_Model.findOneAndUpdate) 方法,使用 **`$set`** 运算符来更新特定设备名称或 ID,而不是更新插入。 (2认同)

Sas*_*waj 8

使用$ push或其他数组更新运算符将元素添加到数组中.有关详细信息,请参阅http://docs.mongodb.org/manual/reference/operator/update/push/#up._S_push

  • $ push:{'devices':{'id':deviceID,'name':deviceName}}应该这样做 (4认同)