sql >> Databáze >  >> NoSQL >> MongoDB

Vnořený dokument MongoDB NodeJS Return

To, o co se pokoušíte, by bylo ve vaší aplikaci docela triviální (tj. kód JS po findOne ), ale pokud to opravdu chcete udělat v mongodb, budete muset použít agregaci. Změňte svůj kód na:

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

Zde je skutečný agregační dotaz, se kterým si můžete pohrát:https://mongoplayground.net/p/ o-xTTa8R42w




  1. Transformujte data MongoDB při hledání

  2. Selhání ověření při pokusu o uložení do mongodb

  3. Mongo DB:Najděte hodnotu vnořeného pole

  4. Při použití expresního balíčku html-pdf se obrázek nevykresluje z cesty dynamického obrázku