[英]How to Update an Object inside an Array inside a MongoDB Collection using Mongoose
[英]How to update object inside array inside object in Mongoose?
我是MongoDB的新手,并且有一个组织的MongoDB集合。 并且有一系列的classes (object)
。 我目前正在将Node.js与Mongoose结合使用,以更新班级内的教师count
。 当前收藏如下。
//organization
{
"_id" : ObjectId("54db07ab12545794bf7c2d1b"),
"name" : “Stackoverflow”,
"classes" : [
{
"name" : “Stack 01”,
"_id" : ObjectId("54db07ab12545794bf7c2d1f"),
"teachers" : [
{
"idUser" : "54d1e8fe14a880bea6288eb6",
"locked" : false,
"count" : 0,
},
{
"idUser" : "54d321cb190c919759b8a8bb",
"locked" : false,
"count" : 0,
},
{
"idUser" : "54d32147ceaa3a665958b096",
"locked" : true,
"count" : 0,
}
]
},
{
"name" : “Stack 02“,
"_id" : ObjectId("54db07ab12545794bf7c2d1c"),
"teachers" : [
{
"idUser" : "54d1e8fe14a880bea6288eb6",
"locked" : false,
"count" : 0,
},
{
"idUser" : "54d32147ceaa3a665958b096",
"locked" : true,
"count" : 0,
}
]
}
]
}
每当我通过猫鼬更新组织时,我都希望增加教师人数。 我这样写。
Organization.findOneAndUpdate(
{_id: "54db07ab12545794bf7c2d1b",
"classes._id": "54db07ab12545794bf7c2d1f"},
{
$inc: {"classes.$.teacher.$.count": 1}
},function(err, org){});
请帮助我查询和增加教师人数。
您可以手动检索它并在javascript级别进行操作,然后将其保存到模型中。
var query = {_id: "54db07ab12545794bf7c2d1b"}
Organization.findOne(query,function(err, org){
var classes = org.classes;
var index = null;
for (var i in classes) {
if (class[i]._id === ObjectID("54db07ab12545794bf7c2d1f")) {
var index = i;
break;
}
}
var teachers = org.classes[index].teachers;
for (i in teachers) {
if (teachers[i].idUser === '54d1e8fe14a880bea6288eb6' ) {
teachers[i].count++;
}
}
org.classes[index].teachers = teachers;
org.save();
});
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.