Here is my Schema.
Home = new Schema({
name: { type: String, required: true},
description: {type: String},
administrator: {type : mongoose.Schema.Types.ObjectId, ref: 'User', required: true},
users: [{
_id: {type : mongoose.Schema.Types.ObjectId, ref: 'User'},
email: {type: String},
name: { type: String},
status: { type: Number}
}],
rooms: [Room]
});
module.exports = mongoose.model('Home', Home);
If I want to find a specific user across multiple documents, I could do
Home.find({"users.email": "[email protected]"},{users:1})
This would return all homes with users.email = [email protected]
But the user's field is an array.
"users" : [
{
"status" : 0,
"name" : "Yaknow",
"email" : "[email protected]",
"_id" : ObjectId("5875a42ea469f40c684de385")
},
{
"status" : 1,
"name" : "johnk",
"email" : "[email protected]",
"_id" : ObjectId("586e31c6ce07af6f891f80fd")
}
]
(this is just from one home, if there are many homes, there will be many arrays like this) So the above query will return each user array of each home the user has email in. My question is, how do I update all instances of that JohnK into JohnKirtster? Using this would update every user in the array's name to JohnKirster
Home.update(query, {users.name: "JohnKirster"})
You can use mongodb $ positional operator by setting multi:true
Home.update(
{"users.name": "johnk"}, //query, you can also query for email
{$set: {"users.$.name": "JohnKirster"}},
{"multi": true} //for multiple documents
)
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With