query objects array mongodb multidimensional-array

objects - query mongodb array



Consultar una matriz de matrices en MongoDB (2)

Pregunta interesante, esto hará el truco

db.multiArr.find({''Keys'':{$elemMatch:{$elemMatch:{$in:[''carrot'']}}}})

$elemMatch utilizado para verificar si un elemento en una matriz coincide con la expresión de coincidencia especificada. anidado $elemMatch profundizará en matrices anidadas

Datos de prueba

db.multiArr.insert({"ID" : "fruit1","Keys" : [["apple", "carrot", "banana"]]}) db.multiArr.insert({"ID" : "fruit2","Keys" : [["apple", "orange", "banana"]]}) db.multiArr.find({''Keys'':{$elemMatch:{$elemMatch:{$in:[''carrot'']}}}}) { "_id" : ObjectId("506555212aeb79b5f7374cbf"), "ID" : "fruit1", "Keys" : [ [ "apple", "carrot", "banana" ] ] } db.multiArr.find({''Keys'':{$elemMatch:{$elemMatch:{$in:[''banana'']}}}}) { "_id" : ObjectId("506555212aeb79b5f7374cbf"), "ID" : "fruit1", "Keys" : [ [ "apple", "carrot", "banana" ] ] } { "_id" : ObjectId("5065587e2aeb79b5f7374cc0"), "ID" : "fruit2", "Keys" : [ [ "apple", "orange", "banana" ] ] }

Diga, tengo un documento como este ...

"ID" : "fruit1", "Keys" : [["apple", "carrot", "banana"]]

¿Cómo busco Keys = "zanahoria"? Ninguna de las siguientes sintaxis funciona.

db.myColl.results.find({ "Keys" : "carrot" }); db.myColl.results.find({ "Keys" : [["carrot"]] });

Sin embargo, los siguientes trabajos, pero no útiles.

db.myColl.results.find({ "Keys" : [["apple", "carrot", "banana]]});

Cualquier puntero a esta consulta será útil. Gracias.


si desea encontrar una matriz de datos de primera posición, use 0 como índice de referencia para obtener datos en una matriz anidada.

db.getCollection(''routes'').find({"routeId" : 12,''routes._id'':ObjectId("598da27a713f3e6acd72287f"),''routes.0.stops.0.orders.0._id'':ObjectId("598da27a713f3e6acd722887")})