问题

如果打算为项目选择一款收费、开源的数据库,那么你可能会在MySQL与PostgreSQL之间举棋不定。MySQL与PostgreSQL都是收费、开源、弱小、且功能丰富的数据库。你次要的问题可能是:哪一个才是最好的开源数据库,MySQL还是PostgreSQL呢?该抉择哪一个开源数据库呢?

在抉择数据库时,你所做的是个长期的决策,因为前面如果再扭转决定将是十分艰难且代价昂扬的。你心愿一开始就抉择正确。两个风行的开源数据库MySQL与PostgreSQL经常成为最初要抉择的产品。对这两个开源数据库的高层次概览将会有助于你抉择最适宜本人须要的。

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也只是局部兼容于规范。

论断

尽管有不同的历史、引擎与工具,不过并没有明确的参考可能表明这两个数据库哪一个可能实用于所有状况。很多组织喜爱应用PostgreSQL,因为它的可靠性好,在爱护数据方面很善于,而且是个社区我的项目,不会陷入厂商的牢笼之中。

MySQL更加灵便,提供了更多选项来针对不同的工作进行裁剪。很多时候,对于一个组织来说,对某个软件应用的熟练程度要比个性上的起因更重要。

PostgreSQL绝对于MySQL的劣势

  • 在SQL的规范实现上要比MySQL欠缺,而且性能实现比拟谨严;
  • 存储过程的性能反对要比MySQL好,具备本地缓存执行打算的能力;
  • 对表连贯反对较完整,优化器的性能较完整,反对的索引类型很多,简单查问能力较强;
  • PG主表采纳堆表寄存,MySQL采纳索引组织表,可能反对比MySQL更大的数据量。
  • PG的主备复制属于物理复制,绝对于MySQL基于binlog的逻辑复制,数据的一致性更加牢靠,复制性能更高,对主机性能的影响也更小。
  • MySQL的存储引擎插件化机制,存在锁机制简单影响并发的问题,而PG不存在。

MySQL绝对于PG的劣势:

  • innodb的基于回滚段实现的MVCC机制,绝对PG新老数据一起寄存的基于XID的MVCC机制,是占优的。新老数据一起寄存,须要定时触 发VACUUM,会带来多余的IO和数据库对象加锁开销,引起数据库整体的并发能力降落。而且VACUUM清理不及时,还可能会引发数据收缩;
  • MySQL采纳索引组织表,这种存储形式非常适合基于主键匹配的查问、删改操作,然而对表结构设计存在束缚;
  • MySQL的优化器较简略,零碎表、运算符、数据类型的实现都很精简,非常适合简略的查问操作;
  • MySQL分区表的实现要优于PG的基于继承表的分区实现,次要体现在分区个数达到上千上万后的解决性能差别较大。
  • MySQL的存储引擎插件化机制,使得它的利用场景更加宽泛,比方除了innodb适宜事务处理场景外,myisam适宜静态数据的查问场景。

总结

开源数据库都不是很欠缺,商业数据库oracle在架构和性能方面都还是欠缺很多的。从利用场景来说,PG更加适宜严格的企业应用场景(比方金融、电信、ERP、CRM),而MySQL更加适宜业务逻辑绝对简略、数据可靠性要求较低的互联网场景(比方google、facebook、alibaba)。

MySQL 与 PostgreSQL 比拟,选哪个

为了弄明确PostgreSQL和MySQL的差异,我搜寻了关键字:MySQL vs PostgreSQL,并看了第一页的几个文章。以下是简略总结:

MySQL与PostgreSQL的区别

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一开始焦点在个性和标准规范上。

选哪个?

可能是因为历史起因MySQL在开发者中更风行一些。至多咱们上学时没听说过PostgreSQL,过后不是MS SQL Server就是MySQL,而MySQL是开源的。实事上PostgreSQL直到8.0才官网反对了Windows零碎。

如果没有什么历史起因(比方零碎曾经基于MySQL多年了),或技术积攒起因(共事中MySQL高手多),那么我感觉抉择PostgreSQL不会有错。

乏味的是,我在Google上搜寻 “switch postgresql to mysql” 时,后果中第一页全是 “Switch to PostgreSQL from MySQL”,第二页终于有个是from PostgreSQL to MySQL,不过只有它一个,而且起因不是说PostgreSQL不好,而是因为作者MySQL教训多些。

其实对于应该如何抉择,民工哥认为最终还是要看企业的理论场景,而后来抉择相应的数据库产品,也欢送大家留言探讨,你对这两款数据库产品的应用心得。

作者:祚儿疯
原文:blog.csdn.net/u012414189/article/details/84064146