在 MongoDB 中實現聚合 - 解構、分組和投影?
MongoDB 中的 $unwind 用於將來自輸入文件的陣列欄位解構,並針對每個元素輸出一個文件。
$group 用於按指定的 _id 表示式對輸入文件分組,並針對每個不同的分組輸出一個文件。
$project 用於將帶有請求欄位的文件傳遞到管道中的下一階段。
讓我們建立一個包含文件的集合 -
> db.demo238.insertOne( ... { ... ... "EmailId" : "John@gmail.com", ... "details" : [ ... { ... "Name" : "Bob", ... "isActive" : true ... } ... ] ... } ...); { "acknowledged" : true, "insertedId" : ObjectId("5e4418e3f4cebbeaebec5152") } > > db.demo238.insertOne( ... { ... ... "EmailId" : "Chris@gmail.com", ... "details" : [ ... { ... "Name" : "David" ... } ... ] ... } ...); { "acknowledged" : true, "insertedId" : ObjectId("5e4418e3f4cebbeaebec5153") } > > > db.demo238.insertOne( ... { ... ... "EmailId" : "Mike@gmail.com", ... "details" : [ ... { ... "Name" : "Carol", ... "isActive" : true ... } ... ] ... } ...); { "acknowledged" : true, "insertedId" : ObjectId("5e4418e4f4cebbeaebec5154") }
在 find() 方法的幫助下,從集合中顯示所有文件
> db.demo238.find().pretty();
這將產生以下輸出 -
{ "_id" : ObjectId("5e4418e3f4cebbeaebec5152"), "EmailId" : "John@gmail.com", "details" : [ { "Name" : "Bob", "isActive" : true } ] } { "_id" : ObjectId("5e4418e3f4cebbeaebec5153"), "EmailId" : "Chris@gmail.com", "details" : [ { "Name" : "David" } ] } { "_id" : ObjectId("5e4418e4f4cebbeaebec5154"), "EmailId" : "Mike@gmail.com", "details" : [ { "Name" : "Carol", "isActive" : true } ] }
以下是實現 MongoDB 聚合的查詢 - 解構、分組和投影 -
> db.demo238.aggregate( ... [ ... { "$match": { "details.isActive": true } }, ... { "$unwind": "$details" }, ... { "$match": { "details.isActive": true } }, ... { "$group": { ... "_id": "$details.Name", ... "active": { "$first": "$_id" } ... }} ... ], ... function(err,result) { ... ... } ...);
這將產生以下輸出 -
{ "_id" : "Carol", "active" : ObjectId("5e4418e4f4cebbeaebec5154") } { "_id" : "Bob", "active" : ObjectId("5e4418e3f4cebbeaebec5152") }
廣告