MongoDB
 sql >> Database >  >> NoSQL >> MongoDB

mongodb :query find() in una raccolta

Puoi usare l'aggregazione. $unwind produrrà un documento per ogni vettura. Quindi $match viene utilizzato al posto di find() nel tuo esempio.

const transmission = 'Manual'
const car_color = 'Yellow'
const model_year = 2013
const min_price = 3500000
const max_price = 4000000

const query = { 
    'cars.transmission_type': transmission, 
    'cars.color': car_color, 
    'cars.year': model_year, 
    'cars.PriceInINR': { '$gte': min_price, '$lte': max_price }
}

db.companies.aggregate([
    { '$unwind': '$cars' },
    { '$match': query }
])