一般將NoSQL數(shù)據庫分為四大類:鍵值(Key-Value)存儲數(shù)據庫、列存儲數(shù)據庫、文檔型數(shù)據庫和圖形(Graph)數(shù)據庫。它們的數(shù)據模型、優(yōu)缺點、典型應用場景。
創(chuàng)新互聯(lián)主要從事成都網站設計、成都做網站、外貿網站建設、網頁設計、企業(yè)做網站、公司建網站等業(yè)務。立足成都服務沿灘,10余年網站建設經驗,價格優(yōu)惠、服務專業(yè),歡迎來電咨詢建站服務:028-86922220
鍵值(Key-Value)存儲數(shù)據庫Key指向Value的鍵值對,通常用hash表來實現(xiàn)查找速度快數(shù)據無結構化(通常只被當作字符串或者二進制數(shù)據)內容緩存,主要用于處理大量數(shù)據的高訪問負載,也用于一些日志系統(tǒng)等。
列存儲數(shù)據庫,以列簇式存儲,將同一列數(shù)據存在一起查找速度快,可擴展性強,更容易進行分布式擴展功能相對局限分布式的文件系統(tǒng)。
文檔型數(shù)據庫,Key-Value對應的鍵值對,Value為結構化數(shù)據,數(shù)據結構要求不嚴格,表結構可變(不需要像關系型數(shù)據庫一樣需預先定義表結構),查詢性能不高,而且缺乏統(tǒng)一的查詢語法,Web應用。
圖形(Graph)數(shù)據庫,圖結構,利用圖結構相關算法(如最短路徑尋址,N度關系查找等),很多時候需要對整個圖做計算才能得出需要的信息,而且這種結構不太好做分布式的集群方案,社交網絡,推薦系統(tǒng)等。
NoSQL,泛指非關系型的數(shù)據庫。隨著互聯(lián)網web2.0網站的興起,傳統(tǒng)的關系數(shù)據庫在處理web2.0網站,特別是超大規(guī)模和高并發(fā)的SNS類型的web2.0純動態(tài)網站已經顯得力不從心,出現(xiàn)了很多難以克服的問題,而非關系型的數(shù)據庫則由于其本身的特點得到了非常迅速的發(fā)展。
常見的Nosql數(shù)據庫有:
一、Redis數(shù)據庫
Redis(RemoteDictionaryServer),即遠程字典服務,是一個開源的使用ANSIC語言編寫、支持網絡、可基于內存亦可持久化的日志型、Key-Value數(shù)據庫,并提供多種語言的API。從2010年3月15日起,Redis的開發(fā)工作由VMware主持。從2013年5月開始,Redis的開發(fā)由Pivotal贊助。
二、MongoDB數(shù)據庫
MongoDB是一個介于關系數(shù)據庫和非關系數(shù)據庫之間的產品,是非關系數(shù)據庫當中功能最豐富,最像關系數(shù)據庫的。它支持的數(shù)據結構非常松散,是類似json的bson格式,因此可以存儲比較復雜的數(shù)據類型。
Mongo最大的特點是它支持的查詢語言非常強大,其語法有點類似于面向對象的查詢語言,幾乎可以實現(xiàn)類似關系數(shù)據庫單表查詢的絕大部分功能,而且還支持對數(shù)據建立索引。
擴展資料:
對于NoSQL并沒有一個明確的范圍和定義,但是他們都普遍存在下面一些共同特征:
一、易擴展
NoSQL數(shù)據庫種類繁多,但是一個共同的特點都是去掉關系數(shù)據庫的關系型特性。數(shù)據之間無關系,這樣就非常容易擴展。無形之間,在架構的層面上帶來了可擴展的能力。
二、大數(shù)據量,高性能
NoSQL數(shù)據庫都具有非常高的讀寫性能,尤其在大數(shù)據量下,同樣表現(xiàn)優(yōu)秀。這得益于它的無關系性,數(shù)據庫的結構簡單。一般MySQL使用Query Cache。NoSQL的Cache是記錄級的,是一種細粒度的Cache,所以NoSQL在這個層面上來說性能就要高很多。
三、靈活的數(shù)據模型
NoSQL無須事先為要存儲的數(shù)據建立字段,隨時可以存儲自定義的數(shù)據格式。而在關系數(shù)據庫里,增刪字段是一件非常麻煩的事情。如果是非常大數(shù)據量的表,增加字段簡直就是——個噩夢。這點在大數(shù)據量的Web2.0時代尤其明顯。
四、高可用
NoSQL在不太影響性能的情況,就可以方便地實現(xiàn)高可用的架構。比如Cassandra、HBase模型,通過復制模型也能實現(xiàn)高可用。
參考資料來源:百度百科-NoSQL
什么是NoSQL數(shù)據庫?從名稱“非SQL”或“非關系型”衍生而來,這些數(shù)據庫不使用類似SQL的查詢語言,通常稱為結構化存儲。這些數(shù)據庫自1960年就已經存在,但是直到現(xiàn)在一些大公司(例如Google和Facebook)開始使用它們時,這些數(shù)據庫才流行起來。該數(shù)據庫最明顯的優(yōu)勢是擺脫了一組固定的列、連接和類似SQL的查詢語言的限制。有時,NoSQL這個名稱也可能表示“不僅僅SQL”,來確保它們可能支持SQL。 NoSQL數(shù)據庫使用諸如鍵值、寬列、圖形或文檔之類的數(shù)據結構,并且可以如JSON之類的不同格式存儲。
什么是NoSQL數(shù)據庫?從名稱“非SQL”或“非關系型”衍生而來,這些數(shù)據庫不使用類似SQL的查詢語言,通常稱為結構化存儲。這些數(shù)據庫自1960年就已經存在,但是直到現(xiàn)在一些大公司(例如Google和Facebook)開始使用它們時,這些數(shù)據庫才流行起來。該數(shù)據庫最明顯的優(yōu)勢是擺脫了一組固定的列、連接和類似SQL的查詢語言的限制。有時,NoSQL這個名稱也可能表示“不僅僅SQL”,來確保它們可能支持SQL。 NoSQL數(shù)據庫使用諸如鍵值、寬列、圖形或文檔之類的數(shù)據結構,并且可以如JSON之類的不同格式存儲。
NoSQL,是not only sql,是非關系數(shù)據庫,不同于oracle等關系數(shù)據庫。hadoop,是分布式解決方案,即為Mapreduce(計算的)和HDFS(文件系統(tǒng)),使用Hadoop和NoSQL可以構造海量數(shù)據解決方案。