MongoDB
 sql >> Datenbank >  >> NoSQL >> MongoDB

MongoDB NodeJS Return-Filialdokument

Was Sie versuchen, wäre in Ihrer App ziemlich trivial (d. h. JS-Code nach findOne ), aber wenn Sie dies wirklich in Mongodb tun möchten, müssen Sie die Aggregation verwenden. Ändern Sie Ihren Code in:

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

Hier ist die eigentliche Aggregationsabfrage, mit der Sie herumspielen können:https://mongoplayground.net/p/ o-xTTa8R42w