De "join"-concepten bestaan niet echt in Mongodb, omdat we het van nature hebben over een ongestructureerde database. Op een gegeven moment $lookup
werd toegevoegd en gaf ons een "left join"-mogelijkheid, maar toch vind ik het "verkeerd" om deze gestructureerde concepten te gebruiken bij het omgaan met Mongo.
Dat gezegd hebbende, zou deze volgende pijplijn moeten voldoen aan uw behoeften:
db.Orders.aggregate([
{
$group: {
_id: "$product_id",
sum: {$sum : 1}
}
},
{
$lookup: {
from: "product",
local_field: "_id",
foreign_field: "_id",
as: "product"
}
},
{
$unwind: "$product"
},
{
$project: {
Product_id: "$_id",
OrderCount: "$sum",
ProductName: "$product.Name"
}
}
])