假设我有这个架构:

var UserSchema = new Schema({
    name : {
        firstName : String,
        lastName : String
    }
});

我创建了这个用户:

User.create({
    name : {
        firstName : Bob,
        lastName : Marley
    }
}, function (err, user) {
    if(err) {
        return console.error(err);
    } else {
        return console.log(user);
    }
});

我注意到如果我这样做:

User.findOneAndUpdate({_id: userId}, { name: { firstName : "Damian" } }, function (err, user) {
    if(err) {
        return console.error(err);
    } else {
        return console.log(user);
    }
});

我的用户现在是:

user = {
    name : {
        firstName : "Damian"
    }
}

但是,如果我这样做:

User.findOneAndUpdate({_id: userId}, { "name.firstName" : "Damian" }, function (err, user) {
    if(err) {
        return console.error(err);
    } else {
        return console.log(user);
    }
});

我的用户是:

user = {
    name : {
        firstName : "Damian",
        lastName : "Marley"
    }
}

有没有办法将一个没有填充所有属性的Object传递给findOneAndUpdate ,并保留之前的属性,而不是去除它们? (与Mongo中的$set功能相同)。 这真烦人......

===============>>#1 票数:5 已采纳

平面展平你不完整的嵌套对象,如下所示:

var flatten = require('flat')

flatten({
    name : {
        firstName : "Damian"
    }
})

// { 
//   'name.firstName': 'Damian'
// } 

现在,您可以像在第二个示例中一样调用findOneAndUpdate

===============>>#2 票数:3

如果你通过实际的完全嵌套的对象findOneAndUpdate()或任何其他mongoose更新方法):

Model.findOneAndUpdate({ ... }, {
  name: {
    firstName : "Damian"
  }
})

您将覆盖整个 (嵌套)对象,因此从文档中删除其所有其他属性(在本例中为: lastName )。

要仅更新嵌套对象的特定属性,而不是整个对象,则需要使用嵌套属性的完整路径。

{ "name.firstName" : "Damian" }

(这将使嵌套name对象中的lastName保持不变)

但是,每当更新嵌套对象的属性时,手动处理它都会很烦人。

幸运的是,将传递给findOneAndUpdate()的更新对象展平并不是一个问题 - 所以它永远不会超过一个级别。

有很多方法可以做到这一点,在这个问题中争论: 最快的方法来展平/取消嵌套嵌套的JSON对象

最快的解决方案似乎是使用现成的flat Node.js库。

var flatten = require('flat')

User.findOneAndUpdate(
  { _id: userId },
  // same as passing '{ "name.firstName": "Damian" }':
  flatten({
    name: {
      firstName : "Damian"
    }
  }), function (err, user) {
  if(err) {
    return console.error(err);
  } else {
    return console.log(user);
  }
});

  ask by bmpasini translate from so

未解决问题?本站智能推荐: