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

MongoDB NodeJS Return underdokument

Det, du forsøger at gøre, ville være ret trivielt i din app (dvs. JS-kode efter findOne ), men hvis du virkelig vil gøre det i mongodb, skal du bruge aggregering. Skift din kode til:

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')
}

Her er den faktiske aggregeringsforespørgsel, som du kan lege med:https://mongoplayground.net/p/ o-xTTa8R42w




  1. Filtrering af et indlejret array i MongoDB

  2. MongoDB - Projekt kun det matchende element i en matrix

  3. Redis, vil et emne (pub/sub) altid blive leveret til mindst én abonnent?

  4. er kort/reducer passende til at finde medianen og tilstanden for et sæt værdier for mange poster?