學(xué)習(xí)Node.js全棧框架MEAN-05-MongoDB

MongoDB是一個(gè)比較年輕的數(shù)據(jù)庫(kù)系統(tǒng),但在近些年發(fā)展的很迅速。MongoDB是NoSQL類型的數(shù)據(jù)庫(kù)。

NoSQL

NoSQL,泛指非關(guān)系型的數(shù)據(jù)庫(kù)。隨著互聯(lián)網(wǎng)web2.0網(wǎng)站的興起,傳統(tǒng)的關(guān)系數(shù)據(jù)庫(kù)在應(yīng)付web2.0網(wǎng)站,特別是超大規(guī)模和高并發(fā)的SNS類型的web2.0純動(dòng)態(tài)網(wǎng)站已經(jīng)顯得力不從心,暴露了很多難以克服的問(wèn)題,而非關(guān)系型的數(shù)據(jù)庫(kù)則由于其本身的特點(diǎn)得到了非常迅速的發(fā)展。NoSQL數(shù)據(jù)庫(kù)的產(chǎn)生就是為了解決大規(guī)模數(shù)據(jù)集合多重?cái)?shù)據(jù)種類帶來(lái)的挑戰(zhàn),尤其是大數(shù)據(jù)應(yīng)用難題。 --百度百科

數(shù)據(jù)會(huì)以key-value變量的形式儲(chǔ)存,以文件型數(shù)據(jù)庫(kù)的模式達(dá)到更好的性能。在之前的SQL數(shù)據(jù)庫(kù)中,數(shù)據(jù)儲(chǔ)存到表里,以主鍵或者外鍵的形式進(jìn)行檢索。在文件型數(shù)據(jù)庫(kù)中,數(shù)據(jù)不再儲(chǔ)存在表里,而是以標(biāo)準(zhǔn)文件形式比如JSON或XML。下面以一個(gè)簡(jiǎn)單的博客數(shù)據(jù)庫(kù)為例,SQL形式的數(shù)據(jù)庫(kù)可能需要兩張表來(lái)儲(chǔ)存博文和回復(fù)如下圖:

SQL

文件型數(shù)據(jù)庫(kù)則是以JSON形式,如下圖:

JSON

以上就是關(guān)系型數(shù)據(jù)庫(kù)和文件型 數(shù)據(jù)庫(kù)的最基本區(qū)別,一個(gè)用表,一個(gè)用文件。另外文件型數(shù)據(jù)庫(kù)在修改表(數(shù)據(jù))結(jié)構(gòu)的時(shí)候要比關(guān)系型數(shù)據(jù)庫(kù)要簡(jiǎn)單。

MongoDB

MongoDB有以下特點(diǎn):

BSON格式

類似于JSON形式的數(shù)據(jù)存儲(chǔ)格式Binary-JSON,又很快的讀取速率。

  • 類似JSON,BSON文件是一個(gè)簡(jiǎn)單地key-value object形式的數(shù)據(jù)。一個(gè)文件包含多個(gè)element(元素),每一個(gè)element有一個(gè)name和對(duì)應(yīng)的value。這些文件支持所有JSON支持的數(shù)據(jù)類型。
  • 使用_id字段作為主鍵,由應(yīng)用驅(qū)動(dòng)或者M(jìn)ongoDB server自動(dòng)生成 ObjectId,類型優(yōu)先級(jí)為:
    • 4byte的Unix epoch時(shí)間
    • 3byte的設(shè)備ID
    • 2byte的進(jìn)程ID
    • 3byte的計(jì)數(shù)器,以一個(gè)隨機(jī)數(shù)為起點(diǎn)
      所以一個(gè)Object會(huì)長(zhǎng)成這個(gè)樣子:
BSON

MongoDB ad hoc檢索

對(duì)key-value儲(chǔ)存形式的擴(kuò)展,MongoDB有其類似于SQL的動(dòng)態(tài)檢索語(yǔ)言,下面對(duì)比SQL語(yǔ)言檢索所有title包含mongo的post:

SQL:
SELECT * FROM Posts WHRER Title LIKE ‘%mongo%’;
MongoDB:
db.posts.find({ title:/mongo/});

  • MongoDB indexing,唯一的數(shù)據(jù)結(jié)構(gòu),給某字段設(shè)置index來(lái)提高檢索效率,例子:
    檢索所有評(píng)論次數(shù)超過(guò)10次的博文:
     "_id": ObjectId("52d02240e4b01d67d71ad577"),
     "title": "First Blog Post",
     "comments": [
],
     "commentsCount": 12
   }

MongoDB檢索:
db.posts.find({ commentCount:{$ gt:10} });
為了檢索以上數(shù)據(jù),MongoDB需要查詢所有的posts數(shù)據(jù),然后檢查commentCount是否大于10。但如果commonCount字段的index定義了,效率就會(huì)大大提高。下圖所示index是怎樣工作的:

Index

MongoDB replica set

數(shù)據(jù)的備份,用到再說(shuō),先略了

MongoDB sharding

解決業(yè)務(wù)增長(zhǎng)后的性能問(wèn)題,略

多數(shù)據(jù)庫(kù)

一個(gè)MongoDB服務(wù)可以存儲(chǔ)多個(gè)DB,除非特意設(shè)定,MongoDB默認(rèn)打開(kāi)test數(shù)據(jù)庫(kù),想要切換到其他數(shù)據(jù)庫(kù)使用:
>use mean
切換到名字為mean的數(shù)據(jù)庫(kù),需要注意的是,在你不需要先創(chuàng)建數(shù)據(jù)庫(kù)再去使用,因?yàn)镸ongoDB的數(shù)據(jù)庫(kù)是在插入文件前懶創(chuàng)建的。這是MongoDB的動(dòng)態(tài)數(shù)據(jù)策略。另一個(gè)打開(kāi)數(shù)據(jù)庫(kù)的方法是:
$mongo mean
如果想要列出所有的數(shù)據(jù)庫(kù):
>show dbs

MongoDB collections

一個(gè)MongoDB collection是一些列的db文件,相當(dāng)于SQL數(shù)據(jù)庫(kù)的一些列表。一個(gè)collection是在第一個(gè)文件插入時(shí)被創(chuàng)建的。想要操作collection,要使用collection方法。現(xiàn)在創(chuàng)建一個(gè)posts collection:
`>db.posts.insert({"title:"First Post","user":"bob"})
上述,會(huì)自動(dòng)建一個(gè)posts collection。下面檢索一下posts:
db.posts.find()
上述,會(huì)看到結(jié)果。

想要看到所有可見(jiàn)的collection:
>show collections

刪除collection:
db.posts.drop()

MongoDB CRUD 操作

Create,Read,Update,Delete。
新建文件:insert()
新建object:update() 和 save()

新建文件

使用insert()創(chuàng)建文件:

> db.posts.insert({"title":"Second Post", "user": "alice"})

使用update()創(chuàng)建文件

> db.posts.update({
  "user": "alice"
}, {
  "title": "Second Post",
  "user": "alice"
}, {
  upsert: true
})

上述,DB首先會(huì)去查找作者是alice的post,然后更新;如果沒(méi)有找到并且upsert是true的話,新建一個(gè)文件。

使用save()創(chuàng)建文件

``` > db.posts.save({"title":"Second Post", "user": "alice"}) ``
上述,傳入文件可以有_id也可以沒(méi)有_id。

insert和save的區(qū)別當(dāng)主鍵"_id"不存在時(shí),都是添加一個(gè)新的文檔,但主健"_id"存在時(shí),就有些不同了:
insert:當(dāng)主鍵"_id"在集合中存在時(shí),不做任何處理。
save:當(dāng)主鍵"_id"在集合中存在時(shí),進(jìn)行更新。
save需要遍歷整個(gè)集合,效率沒(méi)有insert快。

讀取文件

讀取文件使用find()方法。

查找條件:

> db.posts.find({ "user": "alice" })
> db.posts.find({ "user": { $in: ["alice", "bob"] } })

AND/OR:
and不用關(guān)鍵字,羅列上就行
> db.posts.find({ "user": "alice", "commentsCount": { $gt: 10 } })
> db.posts.find( { $or: [{ "user": "alice" }, { "user": "bob" }] })

更新文件

update():

> db.posts.update({
  "user": "alice"
}, { $set: {
    "title": "Second Post"
  }
}, {
  multi: true
})

上述,update()有三個(gè)參數(shù),第一個(gè)參數(shù)是指更新哪些數(shù)據(jù)(篩選),第二個(gè)參數(shù)時(shí)更新內(nèi)容,第三個(gè)是強(qiáng)制更新所有符合條件的文件。

save()

> db.posts.save({
  "_id": ObjectId("50691737d386d8fadbd6b01d"),
  "title": "Second Post",
  "user": "alice"
});

上述,需要傳一個(gè)_id,來(lái)告訴DB你要跟新的文件。** 如果save()沒(méi)有找到object,會(huì)新建一個(gè) **

刪除

使用remove()來(lái)刪除文件

刪除所有:

> db.posts.remove()

刪除多個(gè):

> db.posts.remove({ "user": "alice" })

刪除單個(gè):

> db.posts.remove({ "user": "alice" }, true)
上述,將會(huì)刪除第一個(gè)符合條件的文件,留下其他的。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,316評(píng)論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,481評(píng)論 3 415
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事。” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 176,241評(píng)論 0 374
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 62,939評(píng)論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,697評(píng)論 6 409
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 55,182評(píng)論 1 324
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,247評(píng)論 3 441
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 42,406評(píng)論 0 288
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,933評(píng)論 1 334
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,772評(píng)論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 42,973評(píng)論 1 369
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,516評(píng)論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,209評(píng)論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 34,638評(píng)論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 35,866評(píng)論 1 285
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,644評(píng)論 3 391
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 47,953評(píng)論 2 373

推薦閱讀更多精彩內(nèi)容