PostgreSql对比MySQL优势

PostgreSQL与MySQL优劣对比

1、PostgreSQL相对于MySQL的优势

Pgsql可靠性、数据一致性与完整性最为最高优先级,这点上更符合金融的诉求

稳定性极强,比mysql稳定性更好。结合了许多安全存储和扩展最复杂数据工作负载的功能

可靠性,灾难恢复
1.预写日志(WAL)
2.复制:异步,同步,逻辑
3.时间点恢复(pitr),主动备用

安全性
1.身份验证:GSSAPI, SSPI, LDAP, SCRAM-SHA-256, 证书等
2.强大的访问控制系统
3.列和行级安全性

PostgreSQL 的特性包括:

  • 时间点恢复 (PITR) 将数据库还原到特定时间点。
  • 使用 pgBackRest 等工具记录对数据库的所有更改的预写日志 (WAL)。

PostgreSQL 的稳定性极强, Innodb 等引擎在崩溃、断电之类的灾难场景下抗打击能力有了长足进步,然而很多 MySQL 用户都遇到过Server级的数据库丢失的场景

 PostgreSQL的各种丰富的功能和对事务的支持,可以满足实际金融业务的交易需求;

PostgreSQL的物理复制保证数据库零丢失,相对于MySQL基于binlog的逻辑复制。可以高效快速地将数据库可以跨机房,设置跨region同步,可以满足业务的在各region本地高效读的需求

2、极限性能稳定

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

3、有丰富的几何类型

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

4、可以使用函数和条件索引,调优非常灵活

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

5、可以做到同步,异步,半同步复制

PG的主备复制属于物理复制,相对于MySQL基于binlog的逻辑复制,数据的一致性更加可靠,复制性能更高,对主机性能的影响也更小

PostgreSQL完全免费,而且是BSD协议,如果你把PostgreSQL改一改,然后再拿去卖钱,也没有人管你,这一点很重要,这表明了PostgreSQL数据库不会被其它公司控制。相反,MySQL现在主要是被Oracle公司控制。

2、MySQL相对于PG的优势

1)innodb的基于回滚段实现的MVCC机制,相对PG新老数据一起存放的基于XID的MVCC机制,是占优的。新老数据一起存放,需要定时触 发VACUUM,会带来多余的IO和数据库对象加锁开销,引起数据库整体的并发能力下降。而且VACUUM清理不及时,还可能会引发数据膨胀。

2)MySQL采用索引组织表,这种存储方式非常适合基于主键匹配的查询、删改操作,但是对表结构设计存在约束。

3)MySQL的优化器较简单,系统表、运算符、数据类型的实现都很精简,非常适合简单的查询操作。

4)MySQL相对于PG在国内的流行度更高,PG在国内显得就有些落寞了。

5)MySQL的存储引擎插件化机制,使得它的应用场景更加广泛,比如除了innodb适合事务处理场景外,myisam适合静态数据的查询场景。

总结

总体上来说,开源数据库都不是很完善,商业数据库oracle在架构和功能方面都还是完善很多的。从应用场景来说,PG更加适合严格的企业应用场景(比如金融、电信、ERP、CRM),但不仅仅限制于此,PostgreSQL的json,jsonb,hstore等数据格式,特别适用于一些大数据格式的分析;而MySQL更加适合业务逻辑相对简单、数据可靠性要求较低的互联网场景(比如google、facebook、alibaba),当然现在MySQL的在innodb引擎的大力发展,功能表现良好。

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: PostgreSQLMySQL 都是流行的开源关系型数据库管理系统。它们之间的区别主要在于功能、安全性和性能方面。PostgreSQL 提供了较高的安全性,强大的查询功能,更多的数据类型,可扩展性和丰富的存储过程,但是它的性能较低。MySQL 拥有更快的性能,更多的存储引擎选项,但没有 PostgreSQL 的强大的查询功能和安全性。 ### 回答2: PostgreSQLMySQL是两种常见的开源关系型数据库管理系统(RDBMS)。虽然它们都是用来存储和管理数据的,但在一些方面存在一些明显的差异。 首先,两者的数据类型支持有所不同。PostgreSQL支持更多的数据类型,包括数组、JSON、几何类型等,而MySQL的数据类型相对较少。这使得PostgreSQL在处理一些特殊数据类型时更加灵活。 其次,事务处理方面也有一些差异。PostgreSQL具有更强大的事务处理能力,支持较复杂的事务,包括保存点(savepoints)和嵌套事务,而MySQL则相对较简单,通常只支持简单的事务。 在性能方面,MySQL在某些情况下可能更加高效。它的读写性能通常比PostgreSQL更快,并且对于一些简单的应用来说,MySQL可能是更好的选择。但是,对于复杂的数据查询和大规模的并发访问,PostgreSQL通常表现得更强大和稳定。 在功能方面,PostgreSQL提供了更多的高级功能,如触发器、视图、部分索引、全文搜索和地理空间查询等。这些功能可以更好地支持复杂的应用需求。 另外,两者的社区和生态系统也有一些不同。MySQL是使用最广泛的数据库之一,具有较大的用户和开发者社区。它拥有许多工具和插件,可以方便地扩展和集成。PostgreSQL虽然也有一个庞大的社区,但比MySQL小得多,但其社区对于安全性、可靠性和数据完整性方面的关注更加严格。 综上所述,选择使用PostgreSQL还是MySQL取决于具体应用的需求。如果需要处理特殊数据类型、复杂的事务处理或高级功能,那么PostgreSQL可能更合适。而如果对性能要求较高且应用较简单,MySQL可能是更好的选择。 ### 回答3: PostgreSQLMySQL是两种常见的关系型数据库管理系统(RDBMS),它们在特性和功能方面有许多不同之处。 首先,PostgreSQLMySQL的数据类型支持方面有所不同。PostgreSQL提供了更多的数据类型,例如数组、JSON、range等。而MySQL则提供了更多的字符串类型和日期/时间类型。 其次,在事务处理方面,PostgreSQL具有更强大的支持。它支持多版本并发控制(MVCC),允许并发地读取和写入数据,而不会发生冲突。而MySQL的事务处理则使用锁定机制,可能会导致较高的并发冲突和性能瓶颈。 此外,PostgreSQL在复杂查询和高级功能方面更具优势。它支持更多的查询功能,如递归查询、窗口函数、全文搜索等。PostgreSQL还提供了更多的扩展和插件,允许用户根据需要自定义和扩展数据库功能。 但是,MySQL在性能和简单性方面有一些优势MySQL在处理大量简单查询时表现较好,并具有较低的资源消耗。而PostgreSQL由于其更复杂的功能和架构设计,在处理大型数据集和复杂查询时可能会表现较慢。 此外,两种数据库系统在部署和维护方面也有所不同。MySQL具有更简单的安装和配置过程,并且更易于使用和管理。而PostgreSQL的安装和配置可能需要更多的技术知识和经验。 综上所述,PostgreSQLMySQL在数据类型支持、事务处理、查询功能、扩展性等方面存在一些差异。选择使用哪个数据库系统应该根据具体需求和项目特点进行评估和决策。如果需要更强大的功能和性能,以及更高的灵活性和自定义性,则可以选择PostgreSQL。如果需要简单和高效的解决方案,并且对性能要求不高,则可以选择MySQL

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Pjh_666

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值