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

Usa il risultato della query precedente in un'altra query in mongodb

Puoi utilizzare un'aggregazione con un $match per soddisfare la tua condizione e $lookup per mappare il tuo campo locale user al tuo user raccolta _id campo :

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

In Javascript, con mongoose per esempio puoi farlo con :

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