gpt4 book ai didi

node.js - Mongoose MongoDB : updating objects in a nested array

转载 作者:搜寻专家 更新时间:2023-10-31 22:17:48 25 4
gpt4 key购买 nike

我有以下架构

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: 'cannot use the part (skills of skills._id) to traverse the element

实际对象看起来像

{
"_id" : ObjectId("5469753de27a7c082203fd0a"),
"emp_no" : 123,
"skills" : [
{
"skill" : ObjectId("547d5f3021d99d302079446d"),
"startDate" : ISODate("2014-12-02T06:43:27.763Z")
"_id" : ObjectId("547d5f8f21d99d3020794472")
}
],
"__v" : 108

知道我做错了什么吗?

最佳答案

当您调用 update 时在像您在这里所做的模型实例上,第一个参数是应用于该文档的更新操作,因为要更新的文档已经由其 _id 唯一标识。

相反,使用 Model.update在一个操作中完成这一切:

User.update(
{emp_no: req.body.emp_no, 'skills._id': 123},
{'$set': {
'skills.$.startDate': req.body.startDate
}},
function(err, numAffected) {...}
);

关于node.js - Mongoose MongoDB : updating objects in a nested array,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27260573/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com