Hay un enfoque que te permitirá hacerlo de forma atómica.
Debe incrustar userIds
en RoomUsers
recopilación. Algo como
{ "userIds" : [ 1, 2, 3, 4 ], "roomId" : 1 }
Ahora puede utilizar la siguiente consulta de actualización.
db.RoomUsers.update( { roomId : 1, "userIds": { $not: {$size: 5 } } }, { $push : { "userIds":5 } } )