Search code examples
javascriptmongodbfilterfind

how apply in mongoDB multiple conditions if key exist


const filterOptions = {
        carColor: req.query.carColor, 
        languages: { $regex: `${req.query.languages}`, $options: 'i' },
        incomeMonth: { $gte: req.query.incomeMonth },
        incomeYear: { $gte: req.query.incomeYear },
        age: { $gte: query.fromAge, $lt: query.toAge }, // age from - to
        familyStatus: query.familyStatus
    }

    const profiles = await Profile.find(filterOptions)
        .sort({ createdAt: 1 })
        .limit(100)

    return res.json({ success: true, count: profiles?.length, profiles })

for example I have multiple query, and one of theme language key: req.query.language, and I wanna apply only for this query key $regex method, otherwise if empty key for any, I don't wanna pass it into find() method


Solution

  • You should fill the filterOptions object, conditionally, only for keys that exist.

    let filterOptions = {};
    if (req.query.carColor) {
      filterOptions =  {...filterOptions, carColor: req.query.carColor};
    } 
    if (req.query.languages) {
      filterOptions =  {...filterOptions, languages: { $regex: `${req.query.languages}`, $options: 'i' }};
    }
    if (req.query.incomeMonth) {
      filterOptions =  {...filterOptions, incomeMonth: { $gte: req.query.incomeMonth }};
    }
    if (req.query.incomeYear) {
      filterOptions =  {...filterOptions, incomeYear: { $gte: req.query.incomeYear }};
    }
    if (req.query.fromAge && req.query.toAge) {
      filterOptions =  {...filterOptions, age: { $gte: query.fromAge, $lt: query.toAge }};
    }
    if (req.query.filmStatus) {
      filterOptions =  {...filterOptions, familyStatus: query.familyStatus};
    }