MySQL与 PostgreSQL 数据库功能对比

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
云原生数据库 PolarDB MySQL 版,Serverless 5000PCU 100GB
简介: 概述在几个流行的数据库中,我首先接触到的是MySQL,随着工作发展,接触到越来越多的是PostgreSQL数据库。这两个十分流行的开源数据库。在这之后,我就会经常和一些朋友进行讨论:MySQL和PostgreSQL两者之间到底有什么异同点呢?翻阅资料,今天就来学习一下ACID的遵从性(ACID...

概述

在几个流行的数据库中,我首先接触到的是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场景

mysql5.7以后才对JSON的有了支持
简单和性能是设计第一目标,支持可靠性很高的业务存在一定的困难
大数据库支持存在一定的困难,需要做单机多实例

复制功能对比

在这里插入图片描述

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

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

MySQL支持以下类型:

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

主要功能对比

查询相关功能对比

在这里插入图片描述

表的功能支持

在这里插入图片描述

架构功能对比

在这里插入图片描述

视图表功能对比

在这里插入图片描述

加密使用功能对比

在这里插入图片描述

后记

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

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1天前
|
关系型数据库 MySQL 数据库
|
2天前
|
存储 关系型数据库 MySQL
MySQL数据库开发进阶:精通数据库表的创建与管理22
【7月更文挑战第22天】数据库的创建与删除,数据表的创建与管理
11 1
|
2天前
|
存储 负载均衡 关系型数据库
MySQL 8.0相较于之前版本有哪些性能提升 提供了哪些新的功能
MySQL 8.0相较于之前版本有哪些性能提升 提供了哪些新的功能
9 1
|
8天前
|
分布式计算 大数据 关系型数据库
MaxCompute产品使用合集之如何实现类似mysql实例中的数据库功能
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。
|
10天前
|
消息中间件 DataWorks 关系型数据库
DataWorks产品使用合集之遇到无法连接到本地 MySQL 数据库的问题,该如何解决
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
|
9天前
|
关系型数据库 MySQL 调度
MySQL高级功能与优化策略深度探索
MySQL高级功能与优化策略深度探索
|
10天前
|
SQL 监控 关系型数据库
实时计算 Flink版操作报错合集之在设置监控PostgreSQL数据库时,将wal_level设置为logical,出现一些表更新和删除操作报错,怎么办
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
10天前
|
关系型数据库 MySQL 数据库
实时计算 Flink版操作报错合集之在处理PostgreSQL数据库遇到报错。该如何解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
21天前
|
存储 关系型数据库 MySQL
探索MySQL:关系型数据库的基石
MySQL,作为全球最流行的开源关系型数据库管理系统(RDBMS)之一,广泛应用于各种Web应用、企业级应用和数据仓库中
|
19天前
|
缓存 运维 关系型数据库
数据库容灾 | MySQL MGR与阿里云PolarDB-X Paxos的深度对比
经过深入的技术剖析与性能对比,PolarDB-X DN凭借其自研的X-Paxos协议和一系列优化设计,在性能、正确性、可用性及资源开销等方面展现出对MySQL MGR的多项优势,但MGR在MySQL生态体系内也占据重要地位,但需要考虑备库宕机抖动、跨机房容灾性能波动、稳定性等各种情况,因此如果想用好MGR,必须配备专业的技术和运维团队的支持。 在面对大规模、高并发、高可用性需求时,PolarDB-X存储引擎以其独特的技术优势和优异的性能表现,相比于MGR在开箱即用的场景下,PolarDB-X基于DN的集中式(标准版)在功能和性能都做到了很好的平衡,成为了极具竞争力的数据库解决方案。

热门文章

最新文章