近期工作重點一直放在數(shù)據(jù)庫設(shè)計方面,借助這次機會抽時間整理了一些我對PostgreSQL數(shù)據(jù)庫的理解,同時也是對近段時間學(xué)習(xí)的一個總結(jié)。對于很多人而言或許沒有聽說過這個數(shù)據(jù)庫,通常我們耳邊伴隨的都是Oracle、MySQL、Microsoft SQL Server一類的關(guān)系型數(shù)據(jù)庫。
10年積累的成都網(wǎng)站制作、網(wǎng)站建設(shè)、外貿(mào)網(wǎng)站建設(shè)經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認識你,你也不認識我。但先網(wǎng)站設(shè)計后付款的網(wǎng)站建設(shè)流程,更有隆化免費網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
但看下數(shù)據(jù)庫排行榜,或許更能直觀的認識到PostgreSQL數(shù)據(jù)庫的強大與普遍
既然PostgreSQL排行這么高,那為何在國內(nèi)名氣不如其他數(shù)據(jù)庫呢?這其中我認為重點在于兩點:一、市場推廣力度的問題;二、應(yīng)用場景與國內(nèi)大多數(shù)公司場景不符合造成的。詳細等后續(xù)再進行分析。
PostgreSQL可以說是世界上可以獲得的最先進的開放源碼的數(shù)據(jù)庫系統(tǒng),它包括了豐富的數(shù)據(jù)類型的支持,其中有些數(shù)據(jù)類型可以說連商業(yè)數(shù)據(jù)庫都不具備,比如 IP 類型和幾何類型等;它提供了多版本并發(fā)控制,支持幾乎所有 SQL構(gòu)件(包括子查詢,事務(wù)和用戶自定義類型和函數(shù)),并且可以獲得非常廣闊范圍的(開發(fā))語言綁定(包括 C,C++,Java,perl,tcl,和 python);PostgreSQL整體設(shè)計采用了C/S (client/server)結(jié)構(gòu),幾乎支持了所有類型的數(shù)據(jù)庫客戶端接口。其次PostgreSQL因其開源特性,形成了一個龐大的開源服務(wù)團隊,其相關(guān)的開源組件多種多樣(tablefunc、dict_xsyn、fuzzystrmatch、pg_trgm、cube),能滿足大多數(shù)場景下的需求。當(dāng)然還有人稱其是歷史最悠久、實戰(zhàn)經(jīng)驗最豐富的數(shù)據(jù)庫系統(tǒng),它的擴展包括自然語言解析、多維索引、地理查詢、自定義數(shù)據(jù)類型等。
PostgreSQL數(shù)據(jù)庫雖然整體非常強大,但也是存在缺陷的。從市場人員角度上來講,之前在國內(nèi)基本沒有大規(guī)模的使用經(jīng)驗與架構(gòu)設(shè)計,大多數(shù)停留在找個文檔折騰下的程度。這直接導(dǎo)致了該數(shù)據(jù)庫在國內(nèi)市場的低迷,同樣的Mysql數(shù)據(jù)庫在這方面就較為領(lǐng)先了。MySQL在國內(nèi)互聯(lián)網(wǎng)行業(yè)積累了大量的高可用架構(gòu),分布式架構(gòu)與災(zāi)備經(jīng)驗,但是PostgreSQL幾乎為0,但放眼國際網(wǎng),不難看出PostgreSQL的一片天地的。其次在去IOE方面PostgreSQL因語言支持的全面化、數(shù)據(jù)對接遷移、去Oracle難度相比其他都簡單了很多,當(dāng)然MySQL現(xiàn)在對去Oracle有更好的支持了。
其次在安全方面PostgreSQL事務(wù)符合ACID,確保你的提交是完全原子的、一致的、隔離的和持久的。
總結(jié):
PostgreSQL是一個BSD協(xié)議的全開源數(shù)據(jù)庫,其強大的查詢優(yōu)化器、豐富的數(shù)據(jù)類型提供了完善的關(guān)系數(shù)據(jù)存儲(支持部分非關(guān)系數(shù)據(jù)庫存儲)。有豐富的開源cluster軟件支持,可應(yīng)用各種場景下的不同的需求。相比使用MySQL,其核心InnoDB一直被Oracle控制,無法達到最大化的發(fā)揮,其國內(nèi)使用MySQL數(shù)據(jù)庫作為產(chǎn)品核心庫的大多數(shù)都是中小型項目,其原因雖是綜合對比導(dǎo)致,但相比PostgreSQL在中大型項目中的如魚得水,不得不說我更傾向于使用PostgreSQL。
備注:下節(jié)談一下MySQL與PostgreSQL的對比優(yōu)劣勢與使用場景。