區別:1、MySQL傾向於使用者的角度;pg資料庫傾向於理論角度。 2.MySQL一般會將資料合法性驗證交給客戶;pg資料庫在合法性困難方面做得比較嚴格。 3.在SQL的標準實作上,pg資料庫要比MySQL完善,而且功能實作比較嚴謹。
MySQL
#MySQL相對比較年輕,第一次出現在1994年。它聲稱自己是最受歡迎的開源資料庫。 MySQL就是LAMP(用於Web開發的軟體包,包括 Linux、Apache及Perl/PHP/Python)中的M。建構在LAMP堆疊之上的應用程式大多會使用MySQL,包括那些知名的應用,如 WordPress、Drupal、Zend及phpBB等。
一開始,MySQL的設計目標是成為一個快速的Web伺服器後端,使用快速的索引序列存取方法(ISAM),不支援ACID。經過早期快速的發展之 後,MySQL開始支援更多的儲存引擎,並透過InnoDB引擎實現了ACID。 MySQL也支援其他儲存引擎,提供了臨時表的功能(使用MEMORY存 儲引擎),透過MyISAM引擎實現了高速讀取的資料庫,此外還有其他的核心儲存引擎與第三方引擎。
MySQL的文檔非常豐富,有許多品質不錯的免費參考手冊、書籍與線上文檔,還有來自Oracle和第三方廠商的培訓與支援。
MySQL近年來經歷了所有權的變更和一些相當戲劇性的事件。它最初是由MySQL AB開發的,然後在2008年以10億美金的價格賣給了Sun公司,Sun公司又在2010年被Oracle收購。 Oracle支援MySQL的多個版本 本:Standard、Enterprise、Classic、Cluster、Embedded與Community。其中有些是免費下載的,另外一 有些則是收費的。其核心程式碼基於GPL許可,對於不想使用GPL許可的開發者與廠商來說還有商業許可可供使用。
現在,基於最初的MySQL程式碼還有更多的資料庫可供選擇,因為幾個核心的MySQL開發者已經發布了MySQL分支。最初的MySQL創作者之一 Michael “Monty” Widenius貌似後悔將MySQL賣給了Sun公司,於是又開發了他自己的MySQL分支MariaDB,它是免費的,基於GPL許可。由知名的 MySQL開發者Brian Aker所創建的分支Drizzle對其進行了大量的改寫,特別針對多CPU、雲端、網路應用與高並發進行了最佳化。
PostgreSQL
PostgreSQL標榜自己是世界上最先進的開源資料庫。 PostgreSQL的一些粉絲說它能與Oracle相媲美,而且沒有那麼昂貴的價格和傲慢的客服。它擁有很長的歷史,最初是1985年在加州大學柏克萊分校開發的,作為Ingres資料庫的後繼。
PostgreSQL是完全由社群驅動的開源項目,由全世界超過1000名貢獻者所維護。它提供了單一完整功能的版本,而不像MySQL那樣提供了 多個不同的社群版、商業版與企業版。 PostgreSQL基於自由的BSD/MIT許可,組織可以使用、複製、修改和重新分發程式碼,只需要提供一個版權聲 明即可。
可靠性是PostgreSQL的最高優先權。它以堅如磐石的品質和良好的工程化而聞名,支援高事務、任務關鍵型應用。 PostgreSQL的文檔非 常精良,提供了大量免費的線上手冊,也針對舊版本提供了歸檔的參考手冊。 PostgreSQL的社群支援是非常棒的,還有來自獨立廠商的商業支援。
資料一致性與完整性也是PostgreSQL的高優先權特性。 PostgreSQL是完全支援ACID特性的,它對於資料庫存取提供了強大的安全性 保證,充分利用了企業安全工具,如Kerberos與OpenSSL等。你可以定義自己的檢查,根據自己的業務規則確保資料品質。在眾多的管理特性 中,point-in-time recovery(PITR)是非常棒的特性,這是一個靈活的高可用特性,提供了諸如針對失敗恢復創建熱備份以及快照與恢復的能力。但這並不是 PostgreSQL的全部,專案還提供了幾個方法來管理PostgreSQL以實現高可用、負載平衡與複製等,這樣你就可以使用適合自己特定需求的功能 了。
平台
MySQL與PostgreSQL都出現在一些高流量的Web網站上:
MySQL:Slashdot、Twitter 、Facebook與Wikipedia
PostgreSQL:Yahoo使用了一個修改過的PostgreSQL資料庫來處理每天數以億計的事件,還有Reddit和Disqus
MySQL與PostgreSQL都能運作在多個作業系統上,如Linux、Unix、Mac OS X與Windows。他們都是開源、免費的,因此測試他們時的唯一代價就是你的時間與硬體。他們都很靈活且具有可伸縮性,可用在小型系統和大型分散式系統 上。 MySQL在一個領域上要比PostgreSQL更進一步,那就是它的觸角延伸到了嵌入式領域,這是透過libmysqld實現的。 PostgreSQL不支援嵌入式應用,依然堅守在傳統的客戶端/伺服器架構上。
MySQL通常被認為是網站與應用程式的快速資料庫後端,能夠進行快速的讀取和大量的查詢操作,不過在複雜特性與資料完整性檢查方面較不盡如人意。
PostgreSQL是針對事務型企業應用的嚴肅、功能完善的資料庫,支援強ACID特性和許多資料完整性檢查。他們二者都在某些任務上具有很快的速 度,MySQL不同儲存引擎的行為有較大差異。 MyISAM引擎是最快的,因為它只執行很少的資料完整性檢查,適合於後端讀取操作較多的站點,不過對於包含敏感資料的讀取/寫入資料庫來說就是個災難了,因為MyISAM表最終可能會損壞。 MySQL提供了修復MySQL表的工具,不過對於敏感資料來說,支援 ACID特性的InnoDB則是個更好的選擇。
與之相反,PostgreSQL則是個只有單一儲存引擎的完全整合的資料庫。你可以透過調整postgresql.conf檔的參數來改進效能,也可以調整查詢與交易。 PostgreSQL文件對於效能調優提供了非常詳盡的介紹。
MySQL與PostgreSQL都是高可設定的,並且可以針對不同的任務進行對應的最佳化。他們都支持透過擴充功能來添加額外的功能。
一個常見的誤解就是MySQL要比PostgreSQL更容易學習。關係資料庫系統都是非常複雜的,這兩個資料庫的學習曲線其實是差不多的。
標準相容性
PostgreSQL旨在實現SQL相容性(目前標準是ANSI-SQL:2008)。 MySQL則相容於大部分SQL,不過有自己的擴展,可以支 持NoSQL特性,這在參考手冊中都有介紹。每種方式都有優缺點。相容標準會讓資料庫管理員、資料庫開發者與應用程式開發者更舒服一些,因為這意味著他們只需 學習一套標準、一套特性和指令。這會節省時間,提升效率,也不會被鎖定在特定的廠商上。
支援使用非標準的自訂功能的人們認為這樣可以快速採用新的特性,而不必等待標準進程完成。 ANSI/ISO標準不斷演化,因此標準相容性也是 變化的目標:知名的關聯式資料庫Microsoft SQL Server、Oracle與IBM DB2也只是部分相容於標準。
MySQL與PostgreSQL(pg資料庫)的差異
MySQL是應用程式開發者建立出來的DBMS;而PostgreSQL是由資料庫開發者建立出來的DBMS 。
換句話說,MySQL傾向於使用者的角度,回答的問題是「你想解決的是什麼問題」;而PostgreSQL傾向於理論角度,回答的問題是「資料庫應該如何來解決問題” 。
MySQL一般會將資料合法性驗證交給客戶;PostgreSQL在合法性困難方面做得比較嚴格。例如MySQL裡插入 “2012-02-30” 這個時間時,會成功,但結果會是 “0000-00-00”;PostgreSQL不允許插入此值。
通常,PostgreSQL 被認為是特性豐富,而MySQL被認為更快。但這個觀點基本上是在 MySQL 4.x / PostgreSQL 7.x 的事情,現在情況已經改變了,PostgreSQL 在9.x版本速度上有了很大的改進,而MySQL特性也在增加。
在架構上,MySQL分為兩層:上層的SQL層和幾個儲存引擎(例如InnoDB,MyISAM)。 PostgreSQL 只有一個儲存引擎提供這兩個功能。
這兩個資料庫系統都可以針對應用的情境被優化、定制,精確的說哪個性能更好很難。 MySQL專案一開始焦點就在速度上,而PostgreSQL一開始焦點在特性和規範標準上。
PostgreSQL相對於MySQL的優點
1、在SQL的標準實作上要比MySQL完善,而且功能實作比較嚴謹;
2 、儲存過程的功能支援要比MySQL好,具備本地快取執行計畫的能力;
3、對錶連線支援較完整,優化器的功能較完整,支援的索引類型很多,複雜查詢能力較強;
4、PG主表採用堆疊表存放,MySQL採用索引組織表,能夠支援比MySQL更大的資料量。
5、PG的主備複製屬於實體複製,相對於MySQL基於binlog的邏輯複製,資料的一致性更可靠,複製效能更高,對主機效能的影響也更小。
6、MySQL的儲存引擎外掛機制,有鎖定機制複雜影響並發的問題,而PG不存在。
MySQL相對於PG的優勢:
1、innodb的基於回滾段實現的MVCC機制,相對PG新舊資料一起存放的基於XID的MVCC機制,是佔優的。新舊資料一起存放,需要定時觸 發VACUUM,會帶來多餘的IO和資料庫物件加鎖開銷,造成資料庫整體的同時能力下降。而且VACUUM清理不及時,也可能引發資料膨脹;
2、MySQL採用索引組織表,這種儲存方式非常適合基於主鍵匹配的查詢、刪改操作,但對錶結構設計有約束;
3、MySQL的優化器較簡單,系統表、運算子、資料類型的實作都很精簡,非常適合簡單的查詢操作;
4、MySQL分區表的實作要優於PG的基於繼承表的分區實現,主要體現在分區個數達到上千上萬後的處理性能差異較大。
5、MySQL的儲存引擎插件化機制,使得它的應用場景更加廣泛,例如除了innodb適合事務處理場景外,myisam適合靜態資料的查詢場景。
相關推薦:《mysql教學》
###以上是pg資料庫和mysql的差別是什麼?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

MySQL和PostgreSQL:在Web开发中的最佳实践引言:在现代的Web开发领域中,数据库是必不可少的组成部分。在选择数据库时,常见的选择是MySQL和PostgreSQL。本文将介绍在Web开发中使用MySQL和PostgreSQL的最佳实践,并提供一些代码示例。一、适用场景MySQL适用于大多数Web应用程序,特别是那些需要高性能、可扩展性和易于使

MySQL和PostgreSQL:性能对比与优化技巧在开发web应用程序时,数据库是不可或缺的组成部分。而在选择数据库管理系统时,MySQL和PostgreSQL是两个常见的选择。他们都是开源的关系型数据库管理系统(RDBMS),但在性能和优化方面有一些不同之处。本文将比较MySQL和PostgreSQL的性能,并提供一些优化技巧。性能对比在比较两个数据库管

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。

随着数据库技术的发展,数据库管理系统也呈现出多种多样的选择,开发人员可以根据自己的需求和喜好选择最适合自己的数据库。而PostgreSQL作为一种先进的开源关系型数据库系统,越来越受到开发人员的关注和使用。那么,在PHP编程中如何使用PostgreSQL数据库呢?一、安装和配置PostgreSQL数据库在使用PostgreSQL之前,需要先安装和配置它。首先

MySQL和PostgreSQL:数据安全与备份策略引言:在现代社会中,数据成为了企业和个人生活中不可或缺的一部分。对于数据库管理系统来说,数据安全与备份策略是至关重要的,既能保护数据免受丢失或损坏,也能确保恢复数据的可靠性和完整性。本文将重点讨论MySQL和PostgreSQL两种主流关系型数据库系统的数据安全性和备份策略。一、数据安全性方面:(一)用户权

Go语言是一种快速、高效的编程语言,适合构建Web服务和后端应用程序。而PostgreSQL是一个开源的关系型数据库管理系统,承诺提供更高的可靠性、可扩展性和数据安全性。在本文中,我们将深入探讨如何在Go语言中使用PostgreSQL,并提供一些实用的代码示例和技巧。安装和设置PostgreSQL首先,我们需要安装和设置PostgreSQL。可以在官方网


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Dreamweaver Mac版
視覺化網頁開發工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

禪工作室 13.0.1
強大的PHP整合開發環境

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!