Data una collezione come questa: ..MongoDB: Come trovare un documento da un ID all'interno di un documento nidificato
[
{
"_id" : ObjectId("5546329a470000850084a621"),
"name": "Joe",
"surname": "Smith",
"accounts": [
{
"_id" : ObjectId("5546329a470000850084a655"),
"default": true,
"status" : "approved",
"activationTime" : ISODate("2013-05-03T14:37:15.025Z")
},
{
"_id" : ObjectId("5546329a470000850084a688"),
"default": true,
"status" : "approved",
"activationTime" : ISODate("2014-06-03T14:37:15.025Z")
}
]
},
{
"_id" : ObjectId("9546329a470079850084a622"),
"name": "Jimmy",
"surname": "Brown",
"accounts": [
{
"_id" : ObjectId("5546329a470790850084a651"),
"default": true,
"status" : "suspended",
"activationTime" : ISODate("2015-02-03T14:37:15.025Z")
},
{
"_id" : ObjectId("5546329a470019850084a611"),
"default": true,
"status" : "approved",
"activationTime" : ISODate("2015-04-03T14:37:15.025Z")
}
]
},
]
... come faccio a trovare un documento da accounts.N._id
? Ho provato questo ...
db.users.find(
{},
{
"accounts": 0, "accounts": {
"$elemMatch": { "_id" : ObjectId("5546329a470019850084a611"), "default": true }
}
}
)
... ma does't lavoro da quando ho solo il _id
di tutti i documenti:
{ "_id" : ObjectId("5546329a470000850084a621") }
{ "_id" : ObjectId("9546329a470079850084a622") }
Mi sto perdendo qualcosa?
EDIT
Il risultato che ho effettivamente bisogno è qualcosa di simile:
{
"_id" : ObjectId("9546329a470079850084a622"),
"name": "Jimmy",
"surname": "Brown"
}
Per esempio, ho bisogno di trovare da accounts.N._id
ma senza mostrare il documento nidificato in sé.
ringrazio molto ... Io non voglio mostrare il documento nidificato ... vedi il mio post aggiornato. – j3d
@ j3d vedere la mia risposta aggiornata –