|
2010年將是文檔型數(shù)據(jù)庫(kù)的起始年。盡管這樣的勢(shì)頭已經(jīng)持續(xù)多年,現(xiàn)在才是一個(gè)更多,更廣泛的文檔型數(shù)據(jù)庫(kù)出現(xiàn)的年代。從基于云計(jì)算的Amazon到Google,大量開(kāi)源工具,以及隨之誕生的CouchDB和MongoDB。
那么什么是MongoDB?下面有五件事是php開(kāi)發(fā)者應(yīng)該了解的:
1. MongoDB是一個(gè)單獨(dú)的服務(wù)器;
2. MongoDB是基于文檔,而不是基于表;
3. MongoDB中較少的Schema;
4. 你不需要學(xué)習(xí)另外的語(yǔ)言;
5. MongoDB有良好的php支持。
1. MongoDB是一個(gè)單獨(dú)的服務(wù)器
就像MySQL和PostgreSQL一樣,MongoDB將監(jiān)聽(tīng)接入的鏈接。它提供的工具作用包括詢(xún)問(wèn),創(chuàng)建,更新和刪除。理論上,你將跟在MySQL和PostgreSQL一樣的進(jìn)行工作:鏈接,處理,然后再關(guān)閉鏈接。
2. 向行和表說(shuō)再見(jiàn),歡迎文檔和收集器
代替儲(chǔ)存數(shù)據(jù)的表和行,MongoDB將數(shù)據(jù)儲(chǔ)存在文檔中。假如我們有一篇帶標(biāo)題的“文章”,它有多個(gè)作者,一個(gè)主題和標(biāo)簽。所有這些看起來(lái)就像下面:
復(fù)制代碼 代碼如下:
array(
'title'=>'Hello World',
'authors'=>array('John','Sally','Jim'),
'body'=>'Hello world',
'tags'=>array('tag1','tag2','tag3')
);
?>
上面的例子中最關(guān)鍵的就是那一條記錄――這篇文檔――是的,確實(shí)存儲(chǔ)起來(lái)就像是一篇文檔,支持復(fù)合形式的值存儲(chǔ)在同一區(qū)域。不再需要結(jié)構(gòu)化,不需要將數(shù)據(jù)按照表來(lái)區(qū)分。因此,表已經(jīng)不存在了。
3. MongoDB包含較少的schema
MongoDB沒(méi)有schema語(yǔ)言。如果你想新建一種文檔類(lèi)型,你不需要告訴數(shù)據(jù)庫(kù)任何事情。盡管將新的數(shù)據(jù)放到數(shù)據(jù)庫(kù)中就行了。
在第二點(diǎn)中,我模擬了一個(gè)文檔。現(xiàn)在我想為所有區(qū)域定義一個(gè)文章類(lèi)型,所有我需要做的就是將這些數(shù)據(jù)寫(xiě)到數(shù)據(jù)庫(kù)中。如果我決定延緩寫(xiě)入呢?我只需要拉出這部分?jǐn)?shù)據(jù),然后加上日期字段,最后保存就行。
那么數(shù)據(jù)類(lèi)型怎么辦?簡(jiǎn)單的回答就是MongoDB運(yùn)用一種強(qiáng)制系統(tǒng),類(lèi)似JavaScript或者php。如此這樣,數(shù)據(jù)庫(kù)極好的弱化了類(lèi)型的作用。
這有一些漏洞(超大量的數(shù)據(jù)需要一些明確的定義),不過(guò)多數(shù)情況下,你寫(xiě)你的MongoDB代碼就像在php上編程一樣。
4. 你不需要學(xué)習(xí)另外的語(yǔ)言
回憶一下其他你曾寫(xiě)過(guò)的數(shù)據(jù)庫(kù)抽象層。回憶所有你曾使用過(guò)的ORM層。那么你現(xiàn)在可以?huà)仐壦麄兊模贛ongoDB上你用不著他們了。
MongoDB(包含它的php驅(qū)動(dòng))不需要詢(xún)問(wèn)語(yǔ)言。在大多數(shù)案例中,你只需要簡(jiǎn)單的給定一個(gè)指針具體制定你需要的,然后返回你一個(gè)文檔指向。
如果你運(yùn)行一些高階函數(shù)(比如Map-Reduce),你可以通過(guò)JavaScript應(yīng)用加入到MongoDB中去,并且在JavaScript內(nèi)部引擎中運(yùn)行這些腳本。
5. php和MongoDB是天生一對(duì)?
php已經(jīng)對(duì)MongoDB具備很好的支持。Mongo驅(qū)動(dòng)可以作為一個(gè)PECL加載項(xiàng)加入到php,這意味著安裝起來(lái)就像運(yùn)行PECL一樣安裝Mongo。
看到這里,你可以開(kāi)始編寫(xiě)Mongo的API了。更廣一些說(shuō),它和PDO排在一起。不是簡(jiǎn)單的消亡,但是絕對(duì)不同于我們之前開(kāi)發(fā)過(guò)的數(shù)據(jù)庫(kù)。
API的說(shuō)明文檔將包括一個(gè)引導(dǎo)和許多例子,這樣你就可以在短時(shí)間內(nèi)自舉。下面將是對(duì)你十分有用的提示。
MongoDB發(fā)展非常快。
開(kāi)發(fā)時(shí)間非常短,沒(méi)有過(guò)多的模式來(lái)管理,很少(如果有的話(huà))的數(shù)據(jù)映射。
因?yàn)闆](méi)有新的查詢(xún)語(yǔ)言要學(xué)習(xí),代碼的調(diào)整很小。畢竟,你不需要另外的ORM,封包也非常輕。
你的代碼是未來(lái)的保證,可以更輕松的為你的對(duì)象增加更多的領(lǐng)域,甚至是更復(fù)雜的領(lǐng)域。因此你的代碼可以很輕松的適應(yīng)需求的變化。
延伸閱讀
Mongo是一個(gè)高性能,開(kāi)源,無(wú)模式的文檔型數(shù)據(jù)庫(kù),它在許多場(chǎng)景下可用于替代傳統(tǒng)的關(guān)系型數(shù)據(jù)庫(kù)或鍵/值存儲(chǔ)方式。Mongo使用C++開(kāi)發(fā),提供了以下功能:
◆ 面向集合的存儲(chǔ):適合存儲(chǔ)對(duì)象及JSON形式的數(shù)據(jù)。
◆ 動(dòng)態(tài)查詢(xún):Mongo支持豐富的查詢(xún)表達(dá)式。查詢(xún)指令使用JSON形式的標(biāo)記,可輕易查詢(xún)文檔中內(nèi)嵌的對(duì)象及數(shù)組。
◆ 完整的索引支持:包括文檔內(nèi)嵌對(duì)象及數(shù)組。Mongo的查詢(xún)優(yōu)化器會(huì)分析查詢(xún)表達(dá)式,并生成一個(gè)高效的查詢(xún)計(jì)劃。
◆ 查詢(xún)監(jiān)視:Mongo包含一個(gè)監(jiān)視工具用于分析數(shù)據(jù)庫(kù)操作的性能。
◆ 復(fù)制及自動(dòng)故障轉(zhuǎn)移:Mongo數(shù)據(jù)庫(kù)支持服務(wù)器之間的數(shù)據(jù)復(fù)制,支持主-從模式及服務(wù)器之間的相互復(fù)制。復(fù)制的主要目標(biāo)是提供冗余及自動(dòng)故障轉(zhuǎn)移。
◆ 高效的傳統(tǒng)存儲(chǔ)方式:支持二進(jìn)制數(shù)據(jù)及大型對(duì)象(如照片或圖片)。
◆ 自動(dòng)分片以支持云級(jí)別的伸縮性(處于早期alpha階段):自動(dòng)分片功能支持水平的數(shù)據(jù)庫(kù)集群,可動(dòng)態(tài)添加額外的機(jī)器。
MongoDB的主要目標(biāo)是在鍵/值存儲(chǔ)方式(提供了高性能和高度伸縮性)以及傳統(tǒng)的RDBMS系統(tǒng)(豐富的功能)架起一座橋梁,集兩者的優(yōu)勢(shì)于一身。根據(jù)官方網(wǎng)站的描述,Mongo適合用于以下場(chǎng)景:
◆ 網(wǎng)站數(shù)據(jù):Mongo非常適合實(shí)時(shí)的插入,更新與查詢(xún),并具備網(wǎng)站實(shí)時(shí)數(shù)據(jù)存儲(chǔ)所需的復(fù)制及高度伸縮性。
◆ 緩存:由于性能很高,Mongo也適合作為信息基礎(chǔ)設(shè)施的緩存層。在系統(tǒng)重啟之后,由Mongo搭建的持久化緩存層可以避免下層的數(shù)據(jù)源過(guò)載。
◆ 大尺寸,低價(jià)值的數(shù)據(jù):使用傳統(tǒng)的關(guān)系型數(shù)據(jù)庫(kù)存儲(chǔ)一些數(shù)據(jù)時(shí)可能會(huì)比較昂貴,在此之前,很多時(shí)候程序員往往會(huì)選擇傳統(tǒng)的文件進(jìn)行存儲(chǔ)。
◆ 高伸縮性的場(chǎng)景:Mongo非常適合由數(shù)十或數(shù)百臺(tái)服務(wù)器組成的數(shù)據(jù)庫(kù)。Mongo的路線(xiàn)圖中已經(jīng)包含對(duì)MapReduce引擎的內(nèi)置支持。
◆ 用于對(duì)象及JSON數(shù)據(jù)的存儲(chǔ):Mongo的BSON數(shù)據(jù)格式非常適合文檔化格式的存儲(chǔ)及查詢(xún)。
自然,MongoDB的使用也會(huì)有一些限制,例如它不適合:
◆ 高度事務(wù)性的系統(tǒng):例如銀行或會(huì)計(jì)系統(tǒng)。傳統(tǒng)的關(guān)系型數(shù)據(jù)庫(kù)目前還是更適用于需要大量原子性復(fù)雜事務(wù)的應(yīng)用程序。
◆ 傳統(tǒng)的商業(yè)智能應(yīng)用:針對(duì)特定問(wèn)題的BI數(shù)據(jù)庫(kù)會(huì)對(duì)產(chǎn)生高度優(yōu)化的查詢(xún)方式。對(duì)于此類(lèi)應(yīng)用,數(shù)據(jù)倉(cāng)庫(kù)可能是更合適的選擇。
◆ 需要SQL的問(wèn)題。
MongoDB支持OS X、Linux及Windows等操作系統(tǒng),并提供了Python,php,Ruby,Java及C++語(yǔ)言的驅(qū)動(dòng)程序,社區(qū)中也提供了對(duì)Erlang及.NET等平臺(tái)的驅(qū)動(dòng)程序。
php技術(shù):作為PHP程序員應(yīng)該了解MongoDB的五件事,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。