MySQL与 PostgreSQL 数据库功能对比

本文涉及的产品
云原生数据库 PolarDB MySQL 版,Serverless 5000PCU 100GB
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: 概述在几个流行的数据库中,我首先接触到的是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 数据库
docker MySQL删除数据库时的错误(errno: 39)
docker MySQL删除数据库时的错误(errno: 39)
|
1天前
|
关系型数据库 MySQL 数据库连接
用Navicat备份Mysql演示系统数据库的时候出:Too Many Connections
用Navicat备份Mysql演示系统数据库的时候出:Too Many Connections
|
1天前
|
负载均衡 关系型数据库 MySQL
关系型数据库的安装和配置数据库节点
关系型数据库的安装和配置数据库节点
12 3
|
1天前
|
SQL 关系型数据库 数据库
关系型数据库选择合适的数据库管理系统
关系型数据库选择合适的数据库管理系统
8 2
|
2天前
|
SQL 存储 关系型数据库
性能诊断工具DBdoctor如何快速纳管数据库PolarDB-X
DBdoctor是一款基于eBPF技术的数据库性能诊断工具,已通过阿里云PolarDB分布式版(V2.3)认证。PolarDB-X是阿里云的高性能云原生分布式数据库,采用Shared-nothing和存储计算分离架构,支持高可用、水平扩展和低成本存储。PolarDB-X V2.3.0在读写混合场景下对比开源MySQL有30-40%的性能提升。DBdoctor能按MySQL方式纳管PolarDB-X的DN节点,提供性能洞察和诊断。用户可通过指定步骤安装PolarDB-X和DBdoctor,实现数据库的管理和性能监控。
|
2天前
|
Cloud Native 关系型数据库 分布式数据库
数据库性能诊断工具DBdoctor通过阿里云PolarDB产品生态集成认证
DBdoctor(V3.1.0)成功通过阿里云PolarDB分布式版(V2.3)集成认证,展现优秀兼容性和稳定性。此工具是聚好看科技的内核级数据库性能诊断产品,运用eBPF技术诊断SQL执行,提供智能巡检、根因分析和优化建议。最新版V3.1.1增加了对PolarDB-X和OceanBase的支持,以及基于cost的索引诊断功能。PolarDB-X是阿里巴巴的高性能云原生分布式数据库,兼容MySQL生态。用户可通过提供的下载地址、在线试用链接和部署指南体验DBdoctor。
|
2天前
|
关系型数据库 MySQL BI
关系型数据库选择合适的数据库管理系统
关系型数据库选择合适的数据库管理系统
15 4
|
2天前
|
存储 Oracle 关系型数据库
oracle 数据库 迁移 mysql数据库
将 Oracle 数据库迁移到 MySQL 是一项复杂的任务,因为这两种数据库管理系统具有不同的架构、语法和功能。
15 0
|
3天前
|
存储 关系型数据库 分布式数据库
数据库索引回表困难?揭秘PolarDB存储引擎优化技术
PolarDB分布式版存储引擎采用CSM方案均衡资源开销与可用性。
数据库索引回表困难?揭秘PolarDB存储引擎优化技术
|
4天前
|
关系型数据库 Java 数据库
docker部署postgresql数据库和整合springboot连接数据源
docker部署postgresql数据库和整合springboot连接数据源
13 0