欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

MongoDB中使用JOIN操作的方法-創(chuàng)新互聯(lián)

這篇文章給大家分享的是有關(guān)MongoDB中使用JOIN操作的方法的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。

成都創(chuàng)新互聯(lián)專注于錦江企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè)公司,成都商城網(wǎng)站開(kāi)發(fā)。錦江網(wǎng)站建設(shè)公司,為錦江等地區(qū)提供建站服務(wù)。全流程定制開(kāi)發(fā),專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,成都創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)

前言

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

SELECT book.title, publisher.name
FROM book
LEFT JOIN book.publisher_id ON publisher.id;

換句話說(shuō),book表中的publisher_id字段引用了publishers表中的id字典。這些都是很常見(jiàn)的例子:對(duì)于每個(gè)publisher都可以擁有成千上萬(wàn)本書(shū),如果你想更新publisher的信息的時(shí)候,我們只需要更改一條記錄。數(shù)據(jù)的冗余是很小的,因?yàn)槲覀儾恍枰獮槊勘緯?shū)來(lái)重復(fù)更新他的publisher信息,這種技術(shù)已基本當(dāng)做一種規(guī)范化的東西了。SQL數(shù)據(jù)庫(kù)提供了一些列的規(guī)范與約束條件來(lái)保障數(shù)據(jù)關(guān)聯(lián)性。

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

NoSQL == No JOIN?

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

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

面向文檔的數(shù)據(jù)庫(kù),例如MongoDB,被設(shè)計(jì)用來(lái)存儲(chǔ)非結(jié)構(gòu)化的數(shù)據(jù),理想情況下,這些數(shù)據(jù)是在數(shù)據(jù)集合中是相互沒(méi)有關(guān)聯(lián)的,如果一條數(shù)據(jù)包含兩次或者更多次,那數(shù)據(jù)就重復(fù)了。因?yàn)榇蟛糠智闆r下我們還是需要數(shù)據(jù)關(guān)聯(lián)的,只有很少的情況下才會(huì)不需要關(guān)聯(lián)數(shù)據(jù),看來(lái)NoSQL這些特性看來(lái)讓人失望啊。幸運(yùn)的是MongoDB 3.2 介紹了一個(gè)新的$lookup操作,這個(gè)操作可以提供一個(gè)類似于LEFT OUTER JOIN的操作在兩個(gè)或者是更多的條件下。

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

MongoDB Aggregation

$lookup僅僅在 aggregation操作中才被允許使用,想想他作為一個(gè)管道操作:查詢,過(guò)濾,組合結(jié)果。一個(gè)操作的輸出被作為下一個(gè)的輸入。Aggregation比簡(jiǎn)單的查詢操作更難于理解,而且這些操作通常運(yùn)行很慢,然而他們很高效,Aggregation可以使用一個(gè)很好的例子來(lái)解釋,假設(shè)我們使用user數(shù)據(jù)集合來(lái)創(chuàng)建一個(gè)社交平臺(tái),在每個(gè)獨(dú)立的文檔中存儲(chǔ)沒(méi)個(gè)用戶的信息,例如:

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

我們可以向user這個(gè)集合中添加足夠多的用戶,但是每個(gè)MongoDB文檔都必須有一個(gè)為一個(gè)_id字段值,這個(gè)_id字段值就像SQL中的鍵,在我們沒(méi)有明確指定_id的時(shí)候會(huì)被自動(dòng)的加入到文檔中。我們的社交網(wǎng)站現(xiàn)在需要一個(gè)post集合,這個(gè)結(jié)合存儲(chǔ)用戶的評(píng)論,這個(gè)文檔存儲(chǔ)純文本,時(shí)間,評(píng)分,一個(gè)被寫(xiě)到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"
}

我們現(xiàn)在想要顯示最近具有important評(píng)論的二十條數(shù)據(jù),這些數(shù)據(jù)來(lái)自所有的用戶,并且是按照時(shí)間排序的。每一個(gè)返回的文檔中應(yīng)該包含評(píng)論的文本,發(fā)布評(píng)論的時(shí)間,以及相關(guān)的用戶的名字和國(guó)家。

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

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

我們現(xiàn)在需要對(duì)過(guò)濾出來(lái)的文檔按照時(shí)間,使用$sort操作進(jìn)行排序。

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

因?yàn)槲覀円獌H僅返回二十條數(shù)據(jù),我們可以使用$limit來(lái)限制我們需要處理的文檔數(shù)量。

{ "$limit": 20 }

我們現(xiàn)在使用$lookup操作從user集合中連接數(shù)據(jù),這個(gè)操作需要一個(gè)四個(gè)參數(shù)的對(duì)象:

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

      2、from:需要連接的集合

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

      4、as:輸出的字段名字

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

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

在我們的輸出中將會(huì)創(chuàng)建一個(gè)名為userinfo的新字段,他是一個(gè)數(shù)組,其中每個(gè)元素都是在user集合中匹配的元素。

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

在post.user_id與user._id之間,我們具有一對(duì)一的關(guān)系,因?yàn)閷?duì)于每一個(gè)post只有一個(gè)用戶。因此我們的userinfo數(shù)組將會(huì)僅僅包含一個(gè)元素,我們可以說(shuō)使用 $unwind操作來(lái)解構(gòu)他并插入到一個(gè)自文檔中。

{ "$unwind": "$userinfo" }

現(xiàn)在的輸出將會(huì)轉(zhuǎn)化成更加常用的結(jié)構(gòu):

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

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

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

合并上面所有的操作

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

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

結(jié)果是一個(gè)擁有二十個(gè)文檔的集合,例如:

[
 {
 "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很好用而且很高效,但是上面這個(gè)基礎(chǔ)的例子只是一個(gè)組合的集合查詢。他不是一個(gè)對(duì)SQL中的更加高效的JOIN子句的替代。而且MongoDB也提供了一些限制,如果user集合被刪除了,post文檔還是會(huì)保留。

理想情況下,這個(gè)$lookup操作應(yīng)該不會(huì)經(jīng)常使用,如果你需要經(jīng)常使用它,那么你就使用了錯(cuò)誤的數(shù)據(jù)存儲(chǔ)了(數(shù)據(jù)庫(kù)):如果你有相關(guān)聯(lián)的數(shù)據(jù),應(yīng)該使用關(guān)聯(lián)數(shù)據(jù)庫(kù)(SQL)。

也就是說(shuō)$lookup是一個(gè)MongoDB 3.2新加入的,他解決了當(dāng)在Nosql數(shù)據(jù)庫(kù)中使用一些小的相關(guān)聯(lián)的數(shù)據(jù)查詢的時(shí)候一些令人失望的問(wèn)題。

感謝各位的閱讀!關(guān)于“MongoDB中使用JOIN操作的方法”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

網(wǎng)站標(biāo)題:MongoDB中使用JOIN操作的方法-創(chuàng)新互聯(lián)
瀏覽路徑:http://aaarwkj.com/article16/jsggg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶體驗(yàn)網(wǎng)站導(dǎo)航、網(wǎng)站營(yíng)銷、服務(wù)器托管營(yíng)銷型網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

小程序開(kāi)發(fā)
久久草福利视频在线观看| 长腿丝袜美女亚洲一区二区| 91在线看片国产免费观看| 2021天天操夜夜爽| 久久精品免费激情视频| 日韩黄色成人在线观看| 国产区二区三区在线视频| 亚洲国产成人av精品精品国产自| 欧美黄片不用下载在线观看| 欧美黄片一区二区三区三| 亚洲中文字幕婷婷在线| 精品女厕一区二区三区| 亚洲国产中日韩精品综合| 国产色综合一区二区| 偷拍丝袜美腿亚洲超碰| 尤物欧美精品一区二区三区| 美女高潮久久久777| 亚洲成人永久免费精品| 欧美人妻不卡一区二区久久 | 91精品国产综合久久香蕉麻豆| 91国产网址在线观看| 一区二区少妇黄色三区| 日韩高清在线亚洲专区不卡| 日韩黄国产一区二区三| 成人日韩av免费在线观看| 男女性生活视频成年人观看| 日日骚岛国中文字幕av| 日韩精品极品在线免费视频| 亚洲国产欧美日韩在线一区| 婷婷久久五月综合激情| 亚洲国产一区二区三区三州| 国产又粗又爽视频免费| 国产精品麻豆久久av| 国产精品一区二区国产激情久久 | 欧美高清视频看片在线观看| 尤物在线观看精品视频| av免费在线观看麻豆| 日韩成人一级片在线观看| 91欧美精品一区二区| 91成人大片在线观看| 日本久久在线观看视频|