在 MongoDB 中實現類似 MySQL Union 的查詢方法是什麼?
對於類似合併兩個集合的查詢,使用 MongoDB 中的 JOIN 以及 aggregate()。我們用文件建立一個集合 −
> db.demo486.insertOne({_id:1,"Amount":30,"No":4});
{ "acknowledged" : true, "insertedId" : 1 }
> db.demo486.insertOne({_id:2,"Amount":40,"No":2});
{ "acknowledged" : true, "insertedId" : 2 }
> db.demo486.insertOne({_id:3,"Amount":60,"No":6});
{ "acknowledged" : true, "insertedId" : 3 }使用 find() 方法從集合中顯示所有文件 −
> db.demo486.find();
這將產生以下輸出 −
{ "_id" : 1, "Amount" : 30, "No" : 4 }
{ "_id" : 2, "Amount" : 40, "No" : 2 }
{ "_id" : 3, "Amount" : 60, "No" : 6 }以下是用文件建立第二個集合的查詢 −
> db.demo487.insertOne({_id:1,"Price":10,"No":4});
{ "acknowledged" : true, "insertedId" : 1 }
> db.demo487.insertOne({_id:2,"Price":80,"No":9});
{ "acknowledged" : true, "insertedId" : 2 }
> db.demo487.insertOne({_id:3,"Price":20,"No":6});
{ "acknowledged" : true, "insertedId" : 3 }使用 find() 方法從集合中顯示所有文件 −
> db.demo487.find();
這將產生以下輸出 −
{ "_id" : 1, "Price" : 10, "No" : 4 }
{ "_id" : 2, "Price" : 80, "No" : 9 }
{ "_id" : 3, "Price" : 20, "No" : 6 }以下是 MongoDB 中合併兩個查詢的查詢 −
> db.getCollection('demo486').aggregate([
... {$lookup : { from : "demo487",localField : "No", foreignField :"No", as:"demo487"}},
... {$unwind : "$demo487"},
... {
... $group : {
... _id : {
... No :"$No",
... },
... TotalValue : { $sum : { $add: [ "$Amount", "$demo487.Price" ] }}
... }
... },
... {$sort : {"_id.No":1}},
... {
... $project : {
... No :"$_id.No",
... TotalValue : 1,
... _id : 0
... }
... }
... ])這將產生以下輸出 −
{ "TotalValue" : 40, "No" : 4 }
{ "TotalValue" : 80, "No" : 6 }
廣告
資料結構
網路
關係型資料庫管理系統
作業系統
Java
iOS
HTML
CSS
安卓
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP