首先先回答你的問題
第一個問題:mysql和oracle都是關(guān)系型數(shù)據(jù)庫,也就是RDBMS。
第二個問題:redis、riak、hbase、cassandra、mongodb 等都是非關(guān)系型數(shù)據(jù)庫,也就是nosql。
下面我整體幫你介紹下現(xiàn)在市面上主流的數(shù)據(jù)庫分型:
我們項目一般常用的也是接觸最多的應(yīng)該都是關(guān)系型數(shù)據(jù)庫,因為他有一個大殺器就是sql(結(jié)構(gòu)化查詢語言)是一種用于數(shù)據(jù)庫操作的編程語言,名字里帶了個查詢(query),但作用并不限于查詢sql,這個東西可是個好東西啊,可以幫助我們快速的對數(shù)據(jù)庫中的數(shù)據(jù)進(jìn)行增刪改查,還能做一些其他的管理工作。常見的關(guān)系型數(shù)據(jù)庫有:
Access:桌面數(shù)據(jù)庫,只適合少量數(shù)據(jù)時使用。這是微軟Office軟件的一部分,我們安裝Office的時候,都會帶這個數(shù)據(jù)庫。這個數(shù)據(jù)庫方便易用,一般電腦上都會安裝。如果你用這個數(shù)據(jù)庫,在一般電腦上都能打開。
這個數(shù)據(jù)庫只適合少量數(shù)據(jù)時使用,而且親身體會這個數(shù)據(jù)庫容易膨脹、容易崩潰,但是真的有大的企業(yè)這在用這個數(shù)據(jù)庫辦公,他們說每天會對數(shù)據(jù)庫進(jìn)行維護(hù)。
SQL Server:也是微軟的數(shù)據(jù)庫,和Access不同的是,它基于服務(wù)器端,是一種中型數(shù)據(jù)庫。微軟的東西嘛,簡單易學(xué)、上手快。管理工具也是十分強(qiáng)大,和.net一樣,一點一拽就解決戰(zhàn)斗,哈哈。
MySql:開源的數(shù)據(jù)庫,不要錢(被收了,以后不知道收不收費),可以在它的基礎(chǔ)之上擴(kuò)展和修改。很多小企業(yè)、互聯(lián)網(wǎng)企業(yè)喜歡它。MySQL占用系統(tǒng)資源較少,速度較快。這個也是現(xiàn)在互聯(lián)網(wǎng)企業(yè)的標(biāo)配數(shù)據(jù)庫了。
Oracle,也叫“甲骨文”,是一種大型數(shù)據(jù)庫,很穩(wěn)定、很安全,但是價格也比較貴, 我們常聽說的阿里的去IOE運動,那里面的O就是這個oracle數(shù)據(jù)庫。
最后說一下這個 nosql (非關(guān)系型數(shù)據(jù)庫),說明下這個nosql不是 沒有sql的意思啊,是 not only sql(不僅僅有sql的意思),現(xiàn)在互聯(lián)網(wǎng)企業(yè)對系統(tǒng)的并發(fā)要求都比較高,一般關(guān)系型數(shù)據(jù)庫的受到io讀寫的影響,一般并發(fā)都不是很高, nosql的出現(xiàn)就是為了解決這個問題, 分型還是比較細(xì)的,比如:“文檔型數(shù)據(jù)庫”、“圖形數(shù)據(jù)庫”、“列數(shù)據(jù)庫”、“鍵值數(shù)據(jù)庫” 等,每種類型都有其指定的使用場景。
NoSQL數(shù)據(jù)庫的特點是:- 非結(jié)構(gòu)化的存儲。- 基于多維關(guān)系模型。- 具有特有的使用場景。優(yōu)點:- 高并發(fā),大數(shù)據(jù)下讀寫能力較強(qiáng)。- 基本支持分布式,易于擴(kuò)展,可伸縮。- 簡單,弱結(jié)構(gòu)化存儲。缺點:- 關(guān)聯(lián)查詢等復(fù)雜操作能力較弱。- 事務(wù)支持較弱。- 通用性差。好了,以上的回答希望可以幫助到你。