亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MongoDB > 正文

MongoDB中如何使用JOIN操作詳解

2020-03-14 12:56:57
字體:
來源:轉載
供稿:網友

前言

MongoDB是由C++語言所編寫的一種面向文檔的非關系型數據庫(是一種NoSql數據庫實現),也是介于關系型數據庫和非關系型數據庫之間的數據存儲產品,而眾所周知SQL與NoSQL最大的不同之一就是不支持JOIN,在傳統的數據庫中,SQL JOIN子句允許你使用普通的字段,在兩個或者是更多表中的組合表中的每行數據。例如,如果你有表books和publishers,你可以像下面這樣寫命令:

SELECT book.title, publisher.nameFROM bookLEFT JOIN book.publisher_id ON publisher.id;

換句話說,book表中的publisher_id字段引用了publishers表中的id字典。這些都是很常見的例子:對于每個publisher都可以擁有成千上萬本書,如果你想更新publisher的信息的時候,我們只需要更改一條記錄。數據的冗余是很小的,因為我們不需要為每本書來重復更新他的publisher信息,這種技術已基本當做一種規范化的東西了。SQL數據庫提供了一些列的規范與約束條件來保障數據關聯性。

--------------------------------------------------------------------------------

NoSQL == No JOIN?

并不都是這樣吧。。。。。

--------------------------------------------------------------------------------

面向文檔的數據庫,例如MongoDB,被設計用來存儲非結構化的數據,理想情況下,這些數據是在數據集合中是相互沒有關聯的,如果一條數據包含兩次或者更多次,那數據就重復了。因為大部分情況下我們還是需要數據關聯的,只有很少的情況下才會不需要關聯數據,看來NoSQL這些特性看來讓人失望啊。幸運的是MongoDB 3.2 介紹了一個新的$lookup操作,這個操作可以提供一個類似于LEFT OUTER JOIN的操作在兩個或者是更多的條件下。

--------------------------------------------------------------------------------

MongoDB Aggregation

$lookup僅僅在 aggregation操作中才被允許使用,想想他作為一個管道操作:查詢,過濾,組合結果。一個操作的輸出被作為下一個的輸入。Aggregation比簡單的查詢操作更難于理解,而且這些操作通常運行很慢,然而他們很高效,Aggregation可以使用一個很好的例子來解釋,假設我們使用user數據集合來創建一個社交平臺,在每個獨立的文檔中存儲沒個用戶的信息,例如:

{ "_id": ObjectID("45b83bda421238c76f5c1969"), "name": "User One", "email: "userone@email.com", "country": "UK", "dob": ISODate("1999-09-13T00:00:00.000Z")}

我們可以向user這個集合中添加足夠多的用戶,但是每個MongoDB文檔都必須有一個為一個_id字段值,這個_id字段值就像SQL中的鍵,在我們沒有明確指定_id的時候會被自動的加入到文檔中。我們的社交網站現在需要一個post集合,這個結合存儲用戶的評論,這個文檔存儲純文本,時間,評分,一個被寫到user_id字段的玩家引用。

{ "_id": ObjectID("17c9812acff9ac0bba018cc1"), "user_id": ObjectID("45b83bda421238c76f5c1969"), "date: ISODate("2016-09-05T03:05:00.123Z"), "text": "My life story so far", "rating": "important"}

我們現在想要顯示最近具有important評論的二十條數據,這些數據來自所有的用戶,并且是按照時間排序的。每一個返回的文檔中應該包含評論的文本,發布評論的時間,以及相關的用戶的名字和國家。

MongoDB數據庫的aggregate查詢是通過傳遞管道操作的數組,這個數組中順序的定了每個操作。首先,我們需要從所有的post集合中提取出所有的文檔,這些文檔使用$match記性準確rating過濾。

{ "$match": { "rating": "important" } }

我們現在需要對過濾出來的文檔按照時間,使用$sort操作進行排序。

{ "$sort": { "date": -1 } }

因為我們要僅僅返回二十條數據,我們可以使用$limit來限制我們需要處理的文檔數量。

{ "$limit": 20 }

我們現在使用$lookup操作從user集合中連接數據,這個操作需要一個四個參數的對象:

      1、localField:在輸入文檔中的查找字段

      2、from:需要連接的集合

      3、foreignField:需要在from集合中查找的字段

      4、as:輸出的字段名字

所以我們的操作是這樣的:

{ "$lookup": { "localField": "user_id", "from": "user", "foreignField": "_id", "as": "userinfo"} }

在我們的輸出中將會創建一個名為userinfo的新字段,他是一個數組,其中每個元素都是在user集合中匹配的元素。

"userinfo": [ { "name": "User One", ... }]

在post.user_id與user._id之間,我們具有一對一的關系,因為對于每一個post只有一個用戶。因此我們的userinfo數組將會僅僅包含一個元素,我們可以說使用 $unwind操作來解構他并插入到一個自文檔中。

{ "$unwind": "$userinfo" }

現在的輸出將會轉化成更加常用的結構:

"userinfo": { "name": "User One", "email: "userone@email.com", …}

最終我們可以在管道中使用 $project操作返回評論信息,評論的時間,評論的用戶名,國家等。

{ "$project": { "text": 1, "date": 1, "userinfo.name": 1, "userinfo.country": 1} }

合并上面所有的操作

我們最終的聚合查詢匹配的評論,按照順序排序,限制最新的二十條信息,連接用戶的數據,扁平用戶數組,最后只返回我們需要的必須數據,總的命令如下:

db.post.aggregate([ { "$match": { "rating": "important" } }, { "$sort": { "date": -1 } }, { "$limit": 20 }, { "$lookup": { "localField": "user_id", "from": "user", "foreignField": "_id", "as": "userinfo" } }, { "$unwind": "$userinfo" }, { "$project": { "text": 1, "date": 1, "userinfo.name": 1, "userinfo.country": 1 } }]);

結果是一個擁有二十個文檔的集合,例如:

[ { "text": "The latest post", "date: ISODate("2016-09-27T00:00:00.000Z"), "userinfo": {  "name": "User One",  "country": "UK" } }, { "text": "Another post", "date: ISODate("2016-09-26T00:00:00.000Z"), "userinfo": {  "name": "User One",  "country": "UK" } } ...]

MongoDB的$lookup很好用而且很高效,但是上面這個基礎的例子只是一個組合的集合查詢。他不是一個對SQL中的更加高效的JOIN子句的替代。而且MongoDB也提供了一些限制,如果user集合被刪除了,post文檔還是會保留。

理想情況下,這個$lookup操作應該不會經常使用,如果你需要經常使用它,那么你就使用了錯誤的數據存儲了(數據庫):如果你有相關聯的數據,應該使用關聯數據庫(SQL)。

也就是說$lookup是一個MongoDB 3.2新加入的,他解決了當在Nosql數據庫中使用一些小的相關聯的數據查詢的時候一些令人失望的問題。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。

 

注:相關教程知識閱讀請移步到MongoDB頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久精品色欧美aⅴ一区二区| 中文字幕日韩在线播放| 欧美成人精品h版在线观看| 国产亚洲精品一区二555| 日韩成人av一区| 91国内在线视频| 日韩免费在线视频| 欧美在线性爱视频| 欧美午夜www高清视频| 福利一区视频在线观看| 精品国产乱码久久久久久虫虫漫画| 茄子视频成人在线| 亚洲欧美日韩另类| 精品久久香蕉国产线看观看gif| 精品久久久一区二区| 一区二区成人av| 在线精品91av| 欧洲成人在线观看| 久久色精品视频| 91高清在线免费观看| 九九精品在线视频| 456亚洲影院| 亚洲日韩中文字幕在线播放| 欧美xxxx做受欧美| 正在播放欧美一区| 欧美主播福利视频| 国产精品久久久久久久久男| 亚洲日韩欧美视频一区| 国产91精品网站| 久久久精品中文字幕| 成人黄色免费网站在线观看| 亚洲老头老太hd| 91av在线视频观看| 日韩中文字幕国产| 欧美高清性猛交| 欧美日韩一区二区免费视频| 久久国内精品一国内精品| 国内精品久久久久久影视8| 69av视频在线播放| 欧美日韩福利视频| 国产一区二区三区在线观看网站| 欧美亚洲视频在线观看| 姬川优奈aav一区二区| 国产成人亚洲综合| 久久99国产综合精品女同| 亚洲精品一区二区久| 欧美激情中文字幕在线| 成人精品一区二区三区| 欧美黑人性猛交| 成人国产精品免费视频| 国产成人在线播放| 亚洲视频日韩精品| 青青青国产精品一区二区| 911国产网站尤物在线观看| 亚洲精品小视频在线观看| 亚洲国产成人精品久久久国产成人一区| 欧美野外猛男的大粗鳮| 欧美国产日韩精品| 亚洲日本中文字幕免费在线不卡| 日韩电影免费观看中文字幕| 奇米四色中文综合久久| 久久久精品2019中文字幕神马| 久久久久亚洲精品| 国内精品小视频| 青青草原成人在线视频| 国产精品ⅴa在线观看h| 国产高清在线不卡| 亚洲精品电影久久久| 亚州av一区二区| 91免费在线视频| 欧美国产亚洲精品久久久8v| 91网站在线免费观看| 国产精品高潮呻吟视频| 久久精品99无色码中文字幕| 成人免费视频网| 亚洲爱爱爱爱爱| 亚洲人成电影网站色…| 精品自在线视频| 亚洲激情免费观看| 在线成人激情视频| 欧美激情免费视频| 亚洲一区制服诱惑| 国产精品∨欧美精品v日韩精品| 欧美在线观看www| 青青a在线精品免费观看| 亚洲xxxx在线| 777国产偷窥盗摄精品视频| 日本一区二三区好的精华液| 97在线免费观看| 日韩av在线最新| 国产精品久久久久aaaa九色| 日韩视频永久免费观看| 正在播放欧美一区| 国产亚洲精品日韩| 欧美专区在线观看| 亚洲精品国精品久久99热一| 18久久久久久| 久久精品国产亚洲7777| 日韩欧美在线视频免费观看| 国产亚洲视频中文字幕视频| 国产ts人妖一区二区三区| 国产精品久久久久久一区二区| 91精品久久久久久久久久另类| 亚洲国产一区二区三区四区| 色多多国产成人永久免费网站| 日韩av影视在线| 91国产美女视频| 久久久久女教师免费一区| 亚洲欧美日韩中文在线| 69久久夜色精品国产7777| 亚洲天堂av综合网| 国产精品看片资源| 欧美国产日本在线| 午夜精品一区二区三区在线视频| 亚洲精选中文字幕| 午夜精品美女自拍福到在线| 国产91色在线| 亚洲日本中文字幕| 欧美日韩国产va另类| 亚洲综合成人婷婷小说| 亚洲精品国产拍免费91在线| 韩国美女主播一区| 亚洲最大福利视频网| 亚洲精品国产品国语在线| 亚洲欧美一区二区三区情侣bbw| 国产精品爱久久久久久久| 欧美在线视频观看免费网站| 日韩一区视频在线| 国产精品三级久久久久久电影| 成人在线中文字幕| 久久久久久网址| 日韩免费观看网站| 亚洲乱码国产乱码精品精| 91中文字幕在线观看| 色无极亚洲影院| 国产精品毛片a∨一区二区三区|国| 亚洲欧美一区二区三区四区| 亚洲xxxx18| 欧美一级电影在线| 美女999久久久精品视频| 日韩精品在线播放| 亚洲成人av资源网| 中文字幕欧美在线| 亚洲大尺度美女在线| 国产亚洲精品久久久久久| 成人激情综合网| 国产精品久久久久久亚洲调教| 欧美性猛交xxxx免费看久久久| 日韩在线观看网站| 欧美日韩国产精品一区二区不卡中文| 国产不卡av在线免费观看| 欧美在线视频免费播放| 国产精品久久久久久久久久久久| 91系列在线播放| 国产精品丝袜一区二区三区| 久久精品在线播放| 国产丝袜视频一区| 欧美乱大交xxxxx| 国产精品欧美日韩| 91国自产精品中文字幕亚洲| 亚洲已满18点击进入在线看片| 久久电影一区二区| 亚洲成人久久网| 992tv在线成人免费观看|