我有以下架构
var UserSchema = new Schema({
emp_no: Number,
skills: [{
skill: {
type: Schema.Types.ObjectId,
ref: 'Skill'
},
startDate: {type: Date},
}]
});
然后我尝试更新一项特定技能的开始日期。我尝试了几种不同的方法,其中之一是:
User.findOne({emp_no: req.body.emp_no}, function (err, user) {
user.update( {'skills._id': 123}, {'$set': {
'skills.$.startDate': req.body.startDate
}}
}
此特定代码给出: err: '无法使用该部分(技能的技能._id)来遍历该元素
实际的物体看起来像
{
"_id" : ObjectId("5469753de27a7c082203fd0a"),
"emp_no" : 123,
"skills" : [
{
"skill" : ObjectId("547d5f3021d99d302079446d"),
"startDate" : ISODate("2014-12-02T06:43:27.763Z")
"_id" : ObjectId("547d5f8f21d99d3020794472")
}
],
"__v" : 108
}
有什么想法我做错了吗?
你打电话时update http://mongoosejs.com/docs/api.html#document_Document-update在像您在这里所做的模型实例上,第一个参数是应用于该文档的更新操作,因为要更新的文档已经由其唯一标识_id
.
相反,使用Model.update http://mongoosejs.com/docs/api.html#model_Model.update只需一次操作即可完成这一切:
User.update(
{emp_no: req.body.emp_no, 'skills._id': 123},
{'$set': {
'skills.$.startDate': req.body.startDate
}},
function(err, numAffected) {...}
);
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)