sql >> Databasteknik >  >> NoSQL >> MongoDB

MongoDB NodeJS Return underdokument

Det du försöker göra skulle vara ganska trivialt i din app (dvs. JS-kod efter findOne ), men om du verkligen vill göra det i mongodb, måste du använda aggregering. Ändra din kod till:

const username = req.body.User.Username;
const user = await Account.aggregate([
    {
        $match: {
            "Users.Username": username
        }
    },
    {
        "$project": {
            _id: false,
            USER: {
                $filter: {
                    input: "$Users",
                    as: "users",
                    cond: {
                        $eq: [
                            "$$users.Username",
                            username
                        ]
                    }
                }
            }
        }
    },
    {
        "$unwind": "$USER"
    },
    {
        "$project": {
            USER_PIN: "$USER.PIN"
        }
    }
]);

if(user.length){
    console.log(user[0].USER_PIN)
}else{
    console.log('Username not found')
}

Här är den faktiska aggregeringsfrågan som du kan leka med:https://mongoplayground.net/p/ o-xTTa8R42w




  1. Synkronisera MongoDB via ssh

  2. Prestandajustering i MapReduce för prestandaförbättring

  3. MongoDB $log

  4. Ta bort ett fält från alla element i array i mongodb