So I need to reference particular subdocuments uniquely from items in my collection. For instance:
User = {
\'name\': \'jim\',
\'documents: [
{\
Yes, using mongo's ObjectId is the way to go. The only thing is: you have to generate them yourself, in the application code. They are meant to be globally unique, different workers won't generate two identical ObjectIds, so there's no race condition in that sense.
All official drivers should provide a way to generate ObjectId. Here's how it is in Ruby:
oid = BSON::ObjectId.new