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

Utiliser le résultat de la requête précédente dans une autre requête dans mongodb

Vous pouvez utiliser une agrégation avec un $match pour correspondre à votre condition et $lookup pour mapper votre champ local user à votre user collection _id champ :

db.a.aggregate(
    [{
        $match: {
            "type": ObjectId("50ed90f5a70defef23000002"),
            "config.name": "alpha"
        }
    }, {
        $lookup: {
            from: "users",
            localField: "user",
            foreignField: "_id",
            as: "users"
        }
    }, {
        $unwind: "$users"
    }]);

En Javascript, avec mongoose par exemple vous pouvez le faire avec :

YourModel.aggregate(
    [{
        $match: {
            "type": ObjectId("50ed90f5a70defef23000002"),
            "config.name": "alpha"
        }
    }, {
        $lookup: {
            from: "users",
            localField: "user",
            foreignField: "_id",
            as: "users"
        }
    }, {
        $unwind: "$users"
    }],
    function(err, result) {
        console.log("lastname : " + result.users.lastname);
    });