PostgreSQL与MySQL相比,有何优缺点?

日期:2017-08-17      来源:知乎      作者:方圆      编辑:otpub      点击:702次

PostgreSQL

相较于MySQL而言,PostgreSQL具有以下几种优势:

一、 PostgreSQL的稳定性极强,Innodb等引擎在崩溃、断电之类的灾难场景下抗打击能力有了长足进步,然而很多MySQL用户都遇到过Server级的数据库丢失的场景——mysql系统库是MyISAM的,相比之下,PostgreSQL数据库这方面要好一些。

二、任何系统都有它的性能极限,在高并发读写,负载逼近极限下,PostgreSQL的性能指标仍可以维持双曲线甚至对数曲线,到顶峰之后不再下降,而MySQL明显出现一个波峰后下滑(5.5版本之后,在企业级版本中有个插件可以改善很多,不过需要付费)。

三、PostgreSQL多年来在 GIS 领域处于优势地位,因为它有丰富的几何类型,实际上不止几何类型,PostgreSQL有大量字典、数组、bitmap 等数据类型,相比之下mysql就差很多,instagram就是因为PostgreSQL的空间数据库扩展POSTGIS远远强于MYSQL的my spatial而采用PostgreSQL的。

四、PostgreSQL的“无锁定”特性非常突出,甚至包括 vacuum 这样的整理数据空间的操作,这个和PostgreSQL的MVCC实现有关系。

五、PG 的可以使用函数和条件索引,这使得PG数据库的调优非常灵活,mysql就没有这个功能,条件索引在web应用中很重要。

六、PostgreSQL有极其强悍的 SQL 编程能力,有非常丰富的统计函数和统计语法支持,比如分析函数(ORACLE的叫法,PostgreSQL里叫window函数),还可以用多种语言来写存储过程,对于R的支持也很好。这一点上MYSQL就差的很远,很多分析功能都不支持,腾讯内部数据存储主要是MYSQL,但是数据分析主要是HADOOP+PGSQL(听李元佳说过,但是没有验证过)。

七、PostgreSQL的有多种集群架构可以选择,plproxy可以支持语句级的镜像或分片,slony 可以进行字段级的同步设置,standby可以构建WAL文件级或流式的读写分离集群,同步频率和集群策略调整方便,操作非常简单。

八、一般关系型数据库的字符串有限定长度8k左右,无限长TEXT类型的功能受限,只能作为外部大数据访问。而PostgreSQL的TEXT类型可以直接访问,SQL语法内置正则表达式,可以索引,还可以全文检索,或使用xml xpath。用PostgreSQL的话,文档数据库都可以省了。

九,对于WEB应用来说,复制的特性很重要,mysql到现在也是异步复制,PostgreSQL可以做到同步,异步,半同步复制。还有mysql的同步是基于binlog复制,类似oracle golden gate,是基于stream的复制,做到同步很困难,这种方式更加适合异地复制,PostgreSQL的复制基于wal,可以做到同步复制。同时,PostgreSQL还提供stream复制。

十,PostgreSQL对于numa架构的支持比mysql强一些,比MYSQL对于读的性能更好一些,pgsql提交可以完全异步,而mysql的内存表不够实用(因为表锁的原因)

最后说一下我感觉PG不如MySQL的地方。

一,MySQL有一些实用的运维支持,如slow-query.log,这个PostgreSQL肯定可以定制出来,但是如果可以配置使用就更好了。

二,是mysql的innodb引擎,可以充分优化利用系统所有内存,超大内存下PG对内存使用的不那么充分,

三,MySQL的复制可以用多级从库,但是在9.2之前,PostgreSQL不能用从库带从库。

四,从测试结果上看,mysql 5.5的性能提升很大,单机性能强于PostgreSQL,5.6应该会强更多.

五,对于web应用来说,mysql 5.6 的内置MC API功能很好用,PostgreSQL差一些。

另外一些:PostgreSQL和mysql都是背后有商业公司,而且都不是一个公司。大部分开发者,都是拿工资的。说mysql的执行速度比pgsql快很多是不对的,速度接近,而且很多时候取决于你的配置。

对于存储过程,函数,视图之类的功能,现在两个数据库都可以支持了。

另外多线程架构和多进程架构之间没有绝对的好坏,oracle在Lunix上是多进程架构,在windows上是多线程架构。

很多PostgreSQL应用也是24/7的应用,比如skype. 最近几个版本VACUUM基本不影响PGSQL 运行,8.0之后的PGSQL不需要cygwin就可以在windows上运行。

至于说对于事务的支持,mysql和PostgreSQL都没有问题。


想要了解更多关于PostgreSQL信息,请观看OTPUB直播课堂:“2017年PostgreSQL技术论坛

关键字:PostgreSQLMySQL

本站所载作品版权归作者及原出处共同所有。凡本网注明“来源:OTPUB”的所有作品、文章,版权均属于本站,转载、摘编或利用其它方式使用上述作品,应注明“来源:OTPUB” 或 “摘自:OTPUB”。

上一篇: 如何优化VMware虚拟机 下一篇: OTPUB领先IT学习&直播平台...