I´m using mongotemplate for Spring, and I was wondering how I could increment a value of one of my documents that I have in an array atomically. Imagine that we have
{'a':1,
b:[{_id:341432,
c:2
},
{_id:341445,
c:3
}]};
What I would like is increment c from 3 to 4 for the _id 341445
I have been using findAndModify but I dont know how can I make it for a nested document in an array.
Regards.
To update an element in an array field, you can use the positional $ operator
For example, the following js increments c from 3 to 4 for _id 341445:
db.collection.update({a:1, "b._id":341445} , {$inc:{"b.$.c":1}})
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