How to Update Multiple Array Elements in mongodb -
i have mongo document holds array of elements.
i'd reset .handled
attribute of objects in array .profile
= xx. document in following form:
{ "_id" : objectid("4d2d8deff4e6c1d71fc29a07"), "user_id" : "714638ba-2e08-2168-2b99-00002f3d43c0", "events" : [ { "handled" : 1, "profile" : 10, "data" : "....." } { "handled" : 1, "profile" : 10, "data" : "....." } { "handled" : 1, "profile" : 20, "data" : "....." } ... ] }
so, tried following:
.update({"events.profile":10},{$set:{"events.$.handled":0}},false,true)
however updates first matched array element in each document. (that's defined behavior $ - positional operator.)
how can update all matched array elements?
at moment not possible use positional operator update items in array. see jira http://jira.mongodb.org/browse/server-1243
as work around can:
- update each item individually (events.0.handled events.1.handled ...) or...
- read document, edits manually , save replacing older 1 (check "update if current" if want ensure atomic updates)
Comments
Post a Comment