MongoDB
 sql >> Base de Dados >  >> NoSQL >> MongoDB

Consulta de mangusto:encontre um elemento dentro de uma matriz


Usando o $ operador posicional, você pode obter os resultados. No entanto, se você tiver vários elementos no vehicles array todos eles serão retornados no resultado, pois você só pode usar um operador posicional na projeção e está trabalhando com 2 arrays (um dentro do outro).

Eu sugiro que você dê uma olhada na aggregation framework , pois você terá muito mais flexibilidade. Aqui está um exemplo de consulta para sua pergunta que é executado no shell. Não estou familiarizado com o mangusto, mas acho que isso ainda ajudará você e você poderá traduzi-lo:
db.collection.aggregate([
    // Get only the documents where "email" equals "[email protected]" -- REPLACE with params.username
    {"$match" : {email : "[email protected]"}}, 
    // Unwind the "inventories" array
    {"$unwind" : "$inventories"}, 
    // Get only elements where "inventories.title" equals "activeInventory"
    {"$match" : {"inventories.title":"activeInventory"}}, 
    // Unwind the "vehicles" array
    {"$unwind" : "$inventories.vehicles"}, 
    // Filter by vehicle ID -- REPLACE with vehicleID 
    {"$match" : {"inventories.vehicles._id":ObjectId("53440e94c02b3cae81eb0069")}}, 
    // Tidy up the output
    {"$project" : {_id:0, vehicle:"$inventories.vehicles"}}
])

Esta é a saída que você obterá:
{
        "result" : [
                {
                        "vehicle" : {
                                "_id" : ObjectId("53440e94c02b3cae81eb0069"),
                                "tags" : [
                                        "vehicle"
                                ],
                                "details" : [
                                        {
                                                "_id" : ObjectId("53440e94c02b3cae81eb0066"),
                                                "year" : 2007,
                                                "transmission" : "Manual",
                                                "price" : 1000,
                                                "model" : "Firecar",
                                                "mileageReading" : 50000,
                                                "make" : "Bentley",
                                                "interiorColor" : "blue",
                                                "history" : "CarProof",
                                                "exteriorColor" : "blue",
                                                "driveTrain" : "SWD",
                                                "description" : "test vehicle",
                                                "cylinders" : 4,
                                                "mileageType" : "kms"
                                        }
                                ]
                        }
                }
        ],
        "ok" : 1
}