NoSQL與關(guān)系型數(shù)據(jù)庫設(shè)計(jì)理念比較 關(guān)系型數(shù)據(jù)庫中的表都是存儲(chǔ)一些格式化的數(shù)據(jù)結(jié)構(gòu),每個(gè)元組字段的組成都一樣,即使不是每個(gè)元組都需要所有的字段,但數(shù)據(jù)庫會(huì)為每個(gè)元組分配所有的字段,這樣的結(jié)構(gòu)可以便于表與表之間進(jìn)行連接等操作,但從另一個(gè)角度來說它也是關(guān)系型數(shù)據(jù)庫性能瓶頸的一個(gè)因素。而非關(guān)系型數(shù)據(jù)庫以鍵值對(duì)存儲(chǔ),它的結(jié)構(gòu)不固定,每一個(gè)元組可以有不一樣的字段,每個(gè)元組可以根據(jù)需要增加一些自己的鍵值對(duì),這樣就不會(huì)局限于固定的結(jié)構(gòu),可以減少一些時(shí)間和空間的開銷。 特點(diǎn): 它們可以處理超大量的數(shù)據(jù)。 它們運(yùn)行在便宜的PC服務(wù)器集群上。 它們擊碎了性能瓶頸。 沒有過多的操作。 Bootstrap支持 缺點(diǎn): 但是一些人承認(rèn),沒有正式的官方支持,萬一出了差錯(cuò)會(huì)是可怕的,至少很多管理人員是這樣看。 此外,nosql并未形成一定標(biāo)準(zhǔn),各種產(chǎn)品層出不窮,內(nèi)部混亂,各種項(xiàng)目還需時(shí)間來檢驗(yàn)
辰溪網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián),辰溪網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為辰溪1000+提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站建設(shè)公司要多少錢,請(qǐng)找那個(gè)售后服務(wù)好的辰溪做網(wǎng)站的公司定做!
關(guān)系型數(shù)據(jù)庫:SQLServer、Oracle、mysql等
特性:
①采用關(guān)系模型來組織數(shù)據(jù)的數(shù)據(jù)庫;
②事務(wù)的一致性;
③簡(jiǎn)單來說,關(guān)系模型指的就是二維表格模型,而一個(gè)關(guān)系型數(shù)據(jù)庫就是由二維表及其之間的聯(lián)系所組成的一個(gè)數(shù)據(jù)組織。
優(yōu)點(diǎn):
①容易理解:二維表結(jié)構(gòu)是非常貼近邏輯世界一個(gè)概念,關(guān)系模型相對(duì)網(wǎng)狀、層次等其他模型來說更容易理解;
②使用方便:通用的SQL語言使得操作關(guān)系型數(shù)據(jù)庫非常方便;
③易于維護(hù):豐富的完整性(實(shí)體完整性、參照完整性和用戶定義的完整性)大大減低了數(shù)據(jù)冗余和數(shù)據(jù)不一致的概率;
④支持SQL,可用于復(fù)雜查詢。
缺點(diǎn):
①為了維護(hù)一致性所付出的巨大代價(jià)就是其讀寫性能比較差;
②固定的表結(jié)構(gòu);
③高并發(fā)讀寫需求;
④海量數(shù)據(jù)的高效率讀寫;
非關(guān)系型數(shù)據(jù)庫:MongoDb、redis、HBase等
特性:
①使用鍵值對(duì)存儲(chǔ)數(shù)據(jù);
②分布式;
③一般不支持ACID特性;
④非關(guān)系型數(shù)據(jù)庫嚴(yán)格上不是一種數(shù)據(jù)庫,應(yīng)該是一種數(shù)據(jù)結(jié)構(gòu)化存儲(chǔ)方法的集合。
優(yōu)點(diǎn):
①無需經(jīng)過sql層的解析,讀寫性能很高;
②基于鍵值對(duì),數(shù)據(jù)沒有耦合性,容易擴(kuò)展;
③存儲(chǔ)數(shù)據(jù)的格式:nosql的存儲(chǔ)格式是key,value形式、文檔形式、圖片形式等等,文檔形式、圖片形式等等,而關(guān)系型數(shù)據(jù)庫則只支持基礎(chǔ)類型。
缺點(diǎn):
①不提供sql支持,學(xué)習(xí)和使用成本較高;
②無事務(wù)處理,附加功能bi和報(bào)表等支持也不好;
數(shù)據(jù)庫有兩種類型,分別是關(guān)系型數(shù)據(jù)庫與非關(guān)系型數(shù)據(jù)庫。
數(shù)據(jù)庫,簡(jiǎn)而言之可視為電子化的文件柜——存儲(chǔ)電子文件的處所,用戶可以對(duì)文件中的數(shù)據(jù)進(jìn)行新增、截取、更新、刪除等操作。
關(guān)系型數(shù)據(jù)庫主要有:
Oracle、DB2、Microsoft SQL Server、Microsoft Access、MySQL等等。
非關(guān)系型數(shù)據(jù)庫主要有:
NoSql、Cloudant、MongoDb、redis、HBase等等。
擴(kuò)展資料:
非關(guān)系型數(shù)據(jù)庫的優(yōu)勢(shì):
1、性能高:NOSQL是基于鍵值對(duì)的,可以想象成表中的主鍵和值的對(duì)應(yīng)關(guān)系,而且不需要經(jīng)過SQL層的解析,所以性能非常高。
2、可擴(kuò)展性好:同樣也是因?yàn)榛阪I值對(duì),數(shù)據(jù)之間沒有耦合性,所以非常容易水平擴(kuò)展。
關(guān)系型數(shù)據(jù)庫的優(yōu)勢(shì):
1、可以復(fù)雜查詢:可以用SQL語句方便的在一個(gè)表以及多個(gè)表之間做非常復(fù)雜的數(shù)據(jù)查詢。
2、事務(wù)支持良好:使得對(duì)于安全性能很高的數(shù)據(jù)訪問要求得以實(shí)現(xiàn)。
參考資料來源:百度百科-數(shù)據(jù)庫
非關(guān)系型數(shù)據(jù)庫:非關(guān)系型數(shù)據(jù)庫產(chǎn)品是傳統(tǒng)關(guān)系型數(shù)據(jù)庫的功能閹割版本,通過減少用不到或很少用的功能,來大幅度提高產(chǎn)品性能。
非關(guān)系型數(shù)據(jù)庫嚴(yán)格上不是一種數(shù)據(jù)庫,應(yīng)該是一種數(shù)據(jù)結(jié)構(gòu)化存儲(chǔ)方法的集合。
關(guān)系型數(shù)據(jù)庫:是指采用了關(guān)系模型來組織數(shù)據(jù)的數(shù)據(jù)庫。
關(guān)系模型指的就是二維表格模型,而一個(gè)關(guān)系型數(shù)據(jù)庫就是由二維表及其之間的聯(lián)系所組成的一個(gè)數(shù)據(jù)組織。
可以用SQL語句方便的在一個(gè)表以及多個(gè)表之間做非常復(fù)雜的數(shù)據(jù)查詢。
對(duì)于安全性能很高的數(shù)據(jù)訪問要求可以實(shí)現(xiàn)。
價(jià)格
目前基本上大部分主流的非關(guān)系型數(shù)據(jù)庫都是免費(fèi)的。而比較有名氣的關(guān)系型數(shù)據(jù)庫,比如Oracle、DB2、MSSQL是收費(fèi)的。雖然Mysql免費(fèi),但它需要做很多工作才能正式用于生產(chǎn)。
功能
實(shí)際開發(fā)中,有很多業(yè)務(wù)需求,其實(shí)并不需要完整的關(guān)系型數(shù)據(jù)庫功能,非關(guān)系型數(shù)據(jù)庫的功能就足夠使用了。這種情況下,使用性能更高、成本更低的非關(guān)系型數(shù)據(jù)庫當(dāng)然是更明智的選擇。
對(duì)于這兩類數(shù)據(jù)庫,對(duì)方的優(yōu)勢(shì)就是自己的弱勢(shì),反之亦然。
大數(shù)據(jù)時(shí)代數(shù)據(jù)管理方式研究
1數(shù)據(jù)管理技術(shù)的回顧
數(shù)據(jù)管理技術(shù)主要經(jīng)歷了人工管理階段、文件系統(tǒng)階段和數(shù)據(jù)庫系統(tǒng)階段。隨著數(shù)據(jù)應(yīng)用領(lǐng)域的不斷擴(kuò)展,數(shù)據(jù)管理所處的環(huán)境也越來越復(fù)雜,目前廣泛流行的數(shù)據(jù)庫技術(shù)開始暴露出許多弱點(diǎn),面臨著許多新的挑戰(zhàn)。
1.1 人工管理階段
20 世紀(jì) 50 年代中期,計(jì)算機(jī)主要用于科學(xué)計(jì)算。當(dāng)時(shí)沒有磁盤等直接存取設(shè)備,只有紙帶、卡片、磁帶等外存,也沒有操作系統(tǒng)和管理數(shù)據(jù)的專門軟件。該階段管理的數(shù)據(jù)不保存、由應(yīng)用程序管理數(shù)據(jù)、數(shù)據(jù)不共享和數(shù)據(jù)不具有獨(dú)立性等特點(diǎn)。
1.2 文件系統(tǒng)階段
20 世紀(jì) 50 年代后期到 60 年代中期,隨著計(jì)算機(jī)硬件和軟件的發(fā)展,磁盤、磁鼓等直接存取設(shè)備開始普及,這一時(shí)期的數(shù)據(jù)處理系統(tǒng)是把計(jì)算機(jī)中的數(shù)據(jù)組織成相互獨(dú)立的被命名的數(shù)據(jù)文件,并可按文件的名字來進(jìn)行訪問,對(duì)文件中的記錄進(jìn)行存取的數(shù)據(jù)管理技術(shù)。數(shù)據(jù)可以長(zhǎng)期保存在計(jì)算機(jī)外存上,可以對(duì)數(shù)據(jù)進(jìn)行反復(fù)處理,并支持文件的查詢、修改、插入和刪除等操作。其數(shù)據(jù)面向特定的應(yīng)用程序,因此,數(shù)據(jù)共享性、獨(dú)立性差,且冗余度大,管理和維護(hù)的代價(jià)也很大。
1.3數(shù)據(jù)庫階段
20 世紀(jì) 60 年代后期以來,計(jì)算機(jī)性能得到進(jìn)一步提高,更重要的是出現(xiàn)了大容量磁盤,存儲(chǔ)容量大大增加且價(jià)格下降。在此基礎(chǔ)上,才有可能克服文件系統(tǒng)管理數(shù)據(jù)時(shí)的不足,而滿足和解決實(shí)際應(yīng)用中多個(gè)用戶、多個(gè)應(yīng)用程序共享數(shù)據(jù)的要求,從而使數(shù)據(jù)能為盡可能多的應(yīng)用程序服務(wù),這就出現(xiàn)了數(shù)據(jù)庫這樣的數(shù)據(jù)管理技術(shù)。數(shù)據(jù)庫的特點(diǎn)是數(shù)據(jù)不再只針對(duì)某一個(gè)特定的應(yīng)用,而是面向全組織,具有整體的結(jié)構(gòu)性,共享性高,冗余度減小,具有一定的程序與數(shù)據(jù)之間的獨(dú)立性,并且對(duì)數(shù)據(jù)進(jìn)行統(tǒng)一的控制。
2大數(shù)據(jù)時(shí)代的數(shù)據(jù)管理技術(shù)
大數(shù)據(jù)(big data),或稱巨量資料,指的是所涉及的資料量規(guī)模巨大到無法透過目前主流軟件工具,在合理時(shí)間內(nèi)達(dá)到擷取、管理、處理、并整理成為幫助企業(yè)經(jīng)營(yíng)決策更積極目的的資訊。大數(shù)據(jù)有 3 個(gè) V,一是大量化(Volume),數(shù)據(jù)量是持續(xù)快速增加的,從 TB級(jí)別,躍升到 PB 級(jí)別;二是多樣化(Variety),數(shù)據(jù)類型多樣化,結(jié)構(gòu)化數(shù)據(jù)已被視為小菜一碟,圖片、音頻、視頻等非結(jié)構(gòu)化數(shù)據(jù)正以傳統(tǒng)結(jié)構(gòu)化數(shù)據(jù)增長(zhǎng)的兩倍速快速創(chuàng)建;三是快速化 (Velocity),數(shù)據(jù)生成速度快,也就需要快速的處理能力,因此,產(chǎn)生了“1 秒定律”,就是說一般要在秒級(jí)時(shí)間范圍內(nèi)給出分析結(jié)果,時(shí)間太長(zhǎng)就失去價(jià)值了,這個(gè)速度要求是大數(shù)據(jù)處理技術(shù)和傳統(tǒng)的數(shù)據(jù)挖掘技術(shù)最大的區(qū)別。
2.1 關(guān)系型數(shù)據(jù)庫(RDBMS)
20 世紀(jì) 70 年代初,IBM 工程師 Codd 發(fā)表了著名的論文“A Relational Model of Data for Large Shared DataBanks”,標(biāo)志著關(guān)系數(shù)據(jù)庫時(shí)代來臨。關(guān)系數(shù)據(jù)庫的理論基礎(chǔ)是關(guān)系模型,是借助于集合代數(shù)等數(shù)學(xué)概念和方法來處理數(shù)據(jù)庫中的數(shù)據(jù),現(xiàn)實(shí)世界中的實(shí)體以及實(shí)體之間的聯(lián)系非常容易用關(guān)系模型來表示。容易理解的模型、容易掌握的查詢語言、高效的優(yōu)化器、成熟的技術(shù)和產(chǎn)品,使得關(guān)系數(shù)據(jù)庫占據(jù)了數(shù)據(jù)庫市場(chǎng)的絕對(duì)的統(tǒng)治地位。隨著互聯(lián)網(wǎng) web2.0 網(wǎng)站的興起,半結(jié)構(gòu)化和非結(jié)構(gòu)化數(shù)據(jù)的大量涌現(xiàn),傳統(tǒng)的關(guān)系數(shù)據(jù)庫在應(yīng)付 web2.0 網(wǎng)站特別是超大規(guī)模和高并發(fā)的 SNS(全稱 Social Networking Services,即社會(huì)性網(wǎng)絡(luò)服務(wù)) 類型的 web2.0 純動(dòng)態(tài)網(wǎng)站已經(jīng)顯得力不從心,暴露了很多難以克服的問題。
2.2 noSQL數(shù)據(jù)庫
順應(yīng)時(shí)代發(fā)展的需要產(chǎn)生了 noSQL數(shù)據(jù)庫技術(shù),其主要特點(diǎn)是采用與關(guān)系模型不同的數(shù)據(jù)模型,當(dāng)前熱門的 noSQL數(shù)據(jù)庫系統(tǒng)可以說是蓬勃發(fā)展、異軍突起,很多公司都熱情追捧之,如:由 Google 公司提出的 Big Table 和 MapReduce 以及 IBM 公司提出的 Lotus Notes 等。不管是那個(gè)公司的 noSQL數(shù)據(jù)庫都圍繞著大數(shù)據(jù)的 3 個(gè) V,目的就是解決大數(shù)據(jù)的 3個(gè) V 問題。因此,在設(shè)計(jì) noSQL 時(shí)往往考慮以下幾個(gè)原則,首先,采用橫向擴(kuò)展的方式,通過并行處理技術(shù)對(duì)數(shù)據(jù)進(jìn)行劃分并進(jìn)行并行處理,以獲得高速的讀寫速度;其次,解決數(shù)據(jù)類型從以結(jié)構(gòu)化數(shù)據(jù)為主轉(zhuǎn)向結(jié)構(gòu)化、半結(jié)構(gòu)化、非結(jié)構(gòu)化三者的融合的問題;再次,放松對(duì)數(shù)據(jù)的 ACID 一致性約束,允許數(shù)據(jù)暫時(shí)出現(xiàn)不一致的情況,接受最終一致性;最后,對(duì)各個(gè)分區(qū)數(shù)據(jù)進(jìn)行備份(一般是 3 份),應(yīng)對(duì)節(jié)點(diǎn)失敗的狀況等。
對(duì)數(shù)據(jù)的應(yīng)用可以分為分析型應(yīng)用和操作型應(yīng)用,分析型應(yīng)用主要是指對(duì)大量數(shù)據(jù)進(jìn)行分類、聚集、匯總,最后獲得數(shù)據(jù)量相對(duì)小的分析結(jié)果;操作型應(yīng)用主要是指對(duì)數(shù)據(jù)進(jìn)行增加、刪除、修改和查詢以及簡(jiǎn)單的匯總操作,涉及的數(shù)據(jù)量一般比較少,事務(wù)執(zhí)行時(shí)間一般比較短。目前數(shù)據(jù)庫可分為關(guān)系數(shù)據(jù)庫和 noSQL數(shù)據(jù)庫,根據(jù)數(shù)據(jù)應(yīng)用的要求,再結(jié)合目前數(shù)據(jù)庫的種類,所以目前數(shù)據(jù)庫管理方式主要有以下 4 類。
(1)面向操作型的關(guān)系數(shù)據(jù)庫技術(shù)。
首先,傳統(tǒng)數(shù)據(jù)庫廠商提供的基于行存儲(chǔ)的關(guān)系數(shù)據(jù)庫系統(tǒng),如 DB2、Oracle、SQL Server 等,以其高度的一致性、精確性、系統(tǒng)可恢復(fù)性,在事務(wù)處理方面仍然是核心引擎。其次,面向?qū)崟r(shí)計(jì)算的內(nèi)存數(shù)據(jù)庫系統(tǒng),如 Hana、Timesten、Altibase 等通過把對(duì)數(shù)據(jù)并發(fā)控制、查詢和恢復(fù)等操作控制在內(nèi)存內(nèi)部進(jìn)行,所以獲得了非常高的性能,在很多特定領(lǐng)域如電信、證券、網(wǎng)管等得到普遍應(yīng)用。另外,以 VoltDB、Clustrix 和NuoDB 為代表的 new SQL 宣稱能夠在保持 ACDI 特性的同時(shí)提高了事務(wù)處理性能 50 倍 ~60 倍。
(2)面向分析型的關(guān)系數(shù)據(jù)庫技術(shù)。
首先,TeraData 是數(shù)據(jù)倉庫領(lǐng)域的領(lǐng)頭羊,Teradata 在整體上是按 Shared Nothing 架構(gòu)體系進(jìn)行組織的,定位就是大型數(shù)據(jù)倉庫系統(tǒng),支持較高的擴(kuò)展性。其次,面向分析型應(yīng)用,列存儲(chǔ)數(shù)據(jù)庫的研究形成了另一個(gè)重要的潮流。列存儲(chǔ)數(shù)據(jù)庫以其高效的壓縮、更高的 I/O 效率等特點(diǎn),在分析型應(yīng)用領(lǐng)域獲得了比行存儲(chǔ)數(shù)據(jù)庫高得多的性能。如:MonetDB 和 Vertica是一個(gè)典型的基于列存儲(chǔ)技術(shù)的數(shù)據(jù)庫系統(tǒng)。
(3)面向操作型的 noSQL 技術(shù)。
有些操作型應(yīng)用不受 ACID 高度一致性約束,但對(duì)大數(shù)據(jù)處理需要處理的數(shù)據(jù)量非常大,對(duì)速度性能要求也非常高,這樣就必須依靠大規(guī)模集群的并行處理能力來實(shí)現(xiàn)數(shù)據(jù)處理,弱一致性或最終一致性就可以了。這時(shí),操作型 noSQL數(shù)據(jù)庫的優(yōu)點(diǎn)就可以發(fā)揮的淋漓盡致了。如,Hbase 一天就可以有超過 200 億個(gè)到達(dá)硬盤的讀寫操作,實(shí)現(xiàn)對(duì)大數(shù)據(jù)的處理。另外,noSQL數(shù)據(jù)庫是一個(gè)數(shù)據(jù)模型靈活、支持多樣數(shù)據(jù)類型,如對(duì)圖數(shù)據(jù)建模、存儲(chǔ)和分析,其性能、擴(kuò)展性是關(guān)系數(shù)據(jù)庫無法比擬的。
(4)面向分析型的 noSQL 技術(shù)。
面向分析型應(yīng)用的 noSQL 技術(shù)主要依賴于Hadoop 分布式計(jì)算平臺(tái),Hadoop 是一個(gè)分布式計(jì)算平臺(tái),以 HDFS 和 Map Reduce 為用戶提供系統(tǒng)底層細(xì)節(jié)透明的分布式基礎(chǔ)架構(gòu)?!禜adoop 經(jīng)典實(shí)踐染技巧》傳統(tǒng)的數(shù)據(jù)庫廠商 Microsoft,Oracle,SAS,IBM 等紛紛轉(zhuǎn)向 Hadoop 的研究,如微軟公司關(guān)閉 Dryad 系統(tǒng),全力投入 Map Reduce 的研發(fā),Oracle 在 2011 年下半年發(fā)布 Big Plan 戰(zhàn)略計(jì)劃,全面進(jìn)軍大數(shù)據(jù)處理領(lǐng)域,IBM 則早已捷足先登“,沃森(Watson)”計(jì)算機(jī)就是基于 Hadoop 技術(shù)開發(fā)的產(chǎn)物,同時(shí) IBM 發(fā)布了 BigInsights 計(jì)劃,基于 Hadoop,Netezza 和 SPSS(統(tǒng)計(jì)分析、數(shù)據(jù)挖掘軟件)等技術(shù)和產(chǎn)品構(gòu)建大數(shù)據(jù)分析處理的技術(shù)框架。同時(shí)也涌現(xiàn)出一批新公司來研究Hadoop 技術(shù),如 Cloudera、MapRKarmashpere 等。
3數(shù)據(jù)管理方式的展望
通過以上分析,可以看出關(guān)系數(shù)據(jù)庫的 ACID 強(qiáng)調(diào)數(shù)據(jù)一致性通常指關(guān)聯(lián)數(shù)據(jù)之間的邏輯關(guān)系是否正確和完整,而對(duì)于很多互聯(lián)網(wǎng)應(yīng)用來說,對(duì)這一致性和隔離性的要求可以降低,而可用性的要求則更為明顯,此時(shí)就可以采用 noSQL 的兩種弱一致性的理論 BASE 和 CAP.關(guān)系數(shù)據(jù)庫和 noSQL數(shù)據(jù)庫并不是想到對(duì)立的矛盾體,而是可以相互補(bǔ)充的,根據(jù)不同需求使用不同的技術(shù),甚至二者可以共同存在,互不影響。最近幾年,以 Spanner 為代表新型數(shù)據(jù)庫的出現(xiàn),給數(shù)據(jù)庫領(lǐng)域注入新鮮血液,這就是融合了一致性和可用性的 newSQL,這種新型思維方式或許會(huì)是未來大數(shù)據(jù)處理方式的發(fā)展方向。
4 結(jié)束語
隨著云計(jì)算、物聯(lián)網(wǎng)等的發(fā)展,數(shù)據(jù)呈現(xiàn)爆炸式的增長(zhǎng),人們正被數(shù)據(jù)洪流所包圍,大數(shù)據(jù)的時(shí)代已經(jīng)到來。正確利用大數(shù)據(jù)給人們的生活帶來了極大的便利,但與此同時(shí)也給傳統(tǒng)的數(shù)據(jù)管理方式帶來了極大的挑戰(zhàn)。