sql >> Databasteknik >  >> NoSQL >> MongoDB

Det gick inte att lösa löftesavvisning och skicka array som svar

result.forEach ger en rad löften. Du måste lova allt på en gång med Promise.all([])

exports.get_users = (req, res) => {
  SubscriptionPlan.find().then(async (result) => {
    if (!result) {
      return res.status(400).json({ message: "unable to process" });
    }
    let modifiedData = [];
    await Promise.all(
      result.map(async(data) => {
        if (data.processStatus === "active") {
          const response = await Users.findById(data.userId);
          modifiedData.push(response);
        }
      })
    );
    return res.json(modifiedData);
  }).catch((err) => console.log(err));
};

Eller kan hitta på en gång

exports.get_users = async (req, res) => {
  try {
    const result = await SubscriptionPlan.find({ processStatus: "active" });
    if (!result) {
      return res.status(400).json({ message: "unable to process" });
    }
    const ids = result.map(({ userId }) => userId);
    const response = await Users.find({ userId: { $in: ids } });
    return res.json(response);
  } catch (err) {
    console.log(err)
    return res.status(400).json({ message: "unable to process" });
  }
};



  1. MongoDB GridFS VS Direkt disk IO

  2. Hur man ställer in mongofält från variabel

  3. Hur infogar man ett element i MongoDB intern lista?

  4. Autentisering under anslutning till MongoDB-serverinstans med Java