[转帖]PostgreSQL与MySQL 分析对比

postgresql,mysql,分析,对比 · 浏览次数 : 0

小编点评

**ACID 规范对比:MySQL 与 PostgreSQL** | 特性 | MySQL | PostgreSQL | |---|---|---| | ACID 原子性 | 只有 InnoDB 等少量存储引擎支持 | 支持事务 | | 可一致性 | 必须使数据库从一个一致性的状态变到另外一个一致的状态 | 支持事务,但可串行执行 | | 隔离性 | 基于快照的事务隔离级别 | 可串行化快照隔离级别 | | 持久性 | 默认非持久化 | 默认持久化 | | SQL 标准支持度 | 部分支持 | 支持大部分 SQL 2011标准 | | 视图表功能 | 支持 | 支持 | | 加密使用 | 支持加密 | 不支持加密 |

正文

http://www.pgsql.tech/article_101_10000079

概述

在几个流行的数据库中,我首先接触到的是MySQL,随着工作发展,接触到越来越多的是PostgreSQL数据库。这两个十分流行的开源数据库。在这之后,我就会经常和一些朋友进行讨论:MySQL和PostgreSQL两者之间到底有什么异同点呢?
今天我就来说一说

ACID的遵从性(ACID Compliance )对比

PostgreSQL:
完全遵从ACID,确保满足所有ACID的需求
MySQL:
只有InnoDB等少量存储引擎遵从ACID

原子性(Atomic)

Atomic是指事务包含的所有操作要么全部成功,要么全部失败回滚
PostgreSQL是全面支持事务的关系型数据库,不仅DML语句可以在一个事务中,DDL语句也支持事务,即可以把创建多张表时的DDL语句放到一个事务中,这样可以保证这些表要不都创建成功,要不都不成功。

而MySQL无法把多条DDL语句放到一个事务中。PostgreSQL能保证多条DDL的原子性,这是PG的亮点。

一致性(Consistency)

Consistency是指事务必须使数据库从一个一致性的状态变到另外一个一致的状态,也就是执行事务之前和之后的状态都必须处于一致的状态。一致性:例如数据库完整性约束正确;日志状态一致; 索引和数据的一致, 即事务完成后,数据库的一切都是对的。
而两者的约束对比如下

在这里插入图片描述

隔离性(Isolcation)

Isolcation是指并发执行多个事务时,使它们各自好像是系统在给定时间内执行的唯一操作,即每一事务在系统中认为只有该事务在使用系统,不受其它事务干扰。
达到的效果: 对于任意两个并发的事务T1和T2,在事务T1看来,T2要么在T1开始之前就已经结束,要么在T1结束之后才开始,这样每个事务都感觉不到有其他事务在并发地执行。
几种隔离级别的性能比较
在这里插入图片描述

而PostgreSQL和MySQL的隔离性差异如下
MySQL和PostgreSQL都实现了基于快照的事务隔离级别,即snapshot isolation,PostgreSQL还实现了可串行化的快照隔离级别,即SSI。

在这里插入图片描述

持久性(Durability)

Durability是指一个事务一旦被提交了,那么对于数据库中的数据改变就是永久性的,即便是在数据库系统遭遇到故障的情况下也不会丢失提交事务的操作。
早期的MySQL版本中的默认配置不是提交后立即持久化的,即提交后,数据可能丢失(追求性能),PostgreSQL一开始默认就是持久化的,当然也可以设置成非立即持久化。

在这里插入图片描述

对SQL标准的支持度对比

PostgreSQL:
遵从SQL标准支持最好的数据库。SQL2011标准中,179个核心特性(mandatory features ),做到至少160个,也支持了很多附加特性

MySQL:
只有部分支持,基本是只持了SQL 92标准的部分

支持的业务场景对比

PostgreSQL:
既支持OLTP场景也支持OLAP场景,混合性业务场景,类似Oracle数据库。能很好的支持JSON文档型业务场景。金融级的可靠性,设计目标是以稳定性和可靠性为第一目标,支持大数据库,可以可靠支持几十T的大数据库

MySQL:
只支持OLTP场景,不可用于OLAP场景
OLTP和OLAP的中间场景也不适合,如ERP、CRM等系统
对JSON文档型支持不是太好
简单和性能是设计第一目标,支持可靠性很高的业务存在一定的困难
大数据库支持存在一定的困难,需要做单机多实例

复制功能对比

在这里插入图片描述

复制类型的支持
PostgreSQL支持以下类型

单主到单备
单主到多备
物理备库可以读
双向复杂
逻辑的流复制(发布和订阅模式)
级联的复制
全同步、半同步、异步
同步复制中支持最少同步到几个备节点,即保证至少写几份数据

MySQL支持以下类型

单主到单备
单主到多备
单主到单个备再到单个或多个备
循环复制:A->B->C->A
双主复制
异步复制和半同步复制

主要功能对比

查询相关功能对比

在这里插入图片描述

表的功能支持
在这里插入图片描述

架构功能对比
在这里插入图片描述

视图表功能对比
在这里插入图片描述

加密使用功能对比
在这里插入图片描述

后记

总之,PostgreSQL和MySQL是从底层设计原理开始就不一样的两种数据库,在数据量小的时候,数据库更趋于轻量化,MySQL会更适合。但是一旦数据量稍涨,计算量上升,PostgreSQL会是更好的选择。

部分内容摘自唐成培训介绍PPT

文章知识点与官方知识档案匹配,可进一步学习相关知识
PostgreSQL技能树首页概览4111 人正在系统学习中

与[转帖]PostgreSQL与MySQL 分析对比相似的内容:

[转帖]PostgreSQL与MySQL 分析对比

http://www.pgsql.tech/article_101_10000079 概述 在几个流行的数据库中,我首先接触到的是MySQL,随着工作发展,接触到越来越多的是PostgreSQL数据库。这两个十分流行的开源数据库。在这之后,我就会经常和一些朋友进行讨论:MySQL和PostgreSQ

[转帖]用sysbench进行数据库OLTP基准测试

https://www.cnblogs.com/ariesblog/p/13847740.html 基于TPC-C的OLTP基准测试,对比Mysql和PostgreSQL的性能 一、什么是TPC-C和tpmC 1、TPC-C TPC-C是一种旨在衡量联机事务处理(OLTP)系统性能与可伸缩性的行业标

[转帖]sysbench压测postgresql(mysql同理)

准备创建表和数据:sysbench --db-driver=pgsql --time=1 --threads=1000 --report-interval=5 --pgsql-host=192.168.1.35 --pgsql-port=5001 --pgsql-user=testpgs --pgs

[转帖]用sysbench压测mysql、postgresql(蟑螂db)对比

mysql: 准备创建表和数据: sysbench --db-driver=mysql --time=10 --threads=10 --report-interval=1 --mysql-host=172.18.44.84 --mysql-port=7999 --mysql-user=zl --m

[转帖]USQL

usql is a universal command-line interface for PostgreSQL, MySQL, Oracle Database, SQLite3, Microsoft SQL Server, and many other databases including N

[转帖]一文搞懂各种数据库SQL执行计划:MySQL、Oracle等

https://zhuanlan.zhihu.com/p/99331255 MySQL 执行计划 Oracle 执行计划 SQL Server 执行计划 PostgreSQL 执行计划 执行计划(execution plan,也叫查询计划或者解释计划)是数据库执行 SQL 语句的具体步骤,例如通过索

[转帖]MySQL该使用哪种CPU架构服务器?

https://www.cnblogs.com/zhoujinyi/p/16880861.html 1. 摘要 近期,阿里云推出基于 ARM 架构的 RDS MySQL 和 RDS PostgreSQL 实例,现处于邀测阶段,阿里云宣传 ARM 架构的亮点是:在价格下降13%的基础上,平均性能 AR

[转帖]USQL:支持SQL/NoSQL数据库的通用命令行工具

https://ywnz.com/linuxysjk/2342.html USQL 是一款使用 Go 语言开发的支持 SQL/NoSQL 数据库的通用命令行工具,它支持多种主流的数据库软件,目前最新版本是usql 0.7.0。比如 PostgreSQL、MySQL、Oracle Database、S

[转帖]数据库命令行工具USQL、mycli、litecli、pgcli

https://www.cnblogs.com/-wenli/p/11239042.html USQL USQL 是一款使用 Go 语言开发的支持 SQL/NoSQL 数据库的通用命令行工具,它支持多种主流的数据库软件,目前最新版本是usql 0.7.0。比如 PostgreSQL、MySQL、Or

[转帖]4_PostgreSQL存储空间与权限管理

https://www.modb.pro/db/566444?utm_source=index_ori 1.存储空间 表空间: • 表空间可以让我们将不同的表存放在不同的目录下 • 通过文件系统的分离,优化存储空间和I/O吞吐 CREATE TABLESPACE tablespace_name [