MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

Sous-document de retour MongoDB NodeJS

Ce que vous essayez de faire serait assez trivial dans votre application (c'est-à-dire le code JS après findOne ), mais si vous voulez vraiment le faire dans mongodb, vous devrez utiliser l'agrégation. Remplacez votre code par :

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

Voici la requête d'agrégation réelle avec laquelle vous pouvez jouer :https://mongoplayground.net/p/ o-xTTa8R42w