我知道这个问题是重复的,但我不知道为什么我被困住了
Question:
我怎样才能编辑"requirement.$.update"
数组文档,使用 find by_id
and requirement.update._id
(如果需要的话requirement._id
)
// edit version number level2
exports.editVersionNumberPost = function(req, res){
var query = {
date: req.body.date,
number: req.body.number,
description: req.body.description
}
Project.findOneAndUpdate({ name: req.params.name,
"requirement._id" : req.params.versionID,
"requirement.update._id" : req.params.versionNumID},
{"$set":
{"requirement.$.update" : query
}
}, { new: true },
function(err, obj){})
};
我的架构
----------------
namr: String
requirement:[{
version: Number,
update:[{
date: Date,
number: Number,
description: String
}]
}],
--------
您可以使用以下查询
db.getCollection("test").updateOne(
{ "name": req.params.name },
{ "$set": { "requirement.$[outer].update.$[inner].number": 100000 } },
{
"arrayFilters": [
{ "outer._id": mongoose.Types.ObjectId(req.params.versionID) },
{ "inner._id": mongoose.Types.ObjectId(req.params.versionNumID) }
]
}
)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)