您当前的位置:首页 > 电脑百科 > 数据库 > MYSQL

MySQL与 PostgreSQL 数据库功能对比

时间:2019-12-23 11:27:54  来源:  作者:

概述

在几个流行的数据库中,我首先接触到的是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是指事务必须使数据库从一个一致性的状态变到另外一个一致的状态,也就是执行事务之前和之后的状态都必须处于一致的状态。一致性:例如数据库完整性约束正确;日志状态一致; 索引和数据的一致, 即事务完成后,数据库的一切都是对的。
而两者的约束对比如下

MySQL与 PostgreSQL 数据库功能对比

 

隔离性(Isolcation)

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

MySQL与 PostgreSQL 数据库功能对比

 

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

MySQL与 PostgreSQL 数据库功能对比

 

持久性(Durability)

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

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的有了支持
简单和性能是设计第一目标,支持可靠性很高的业务存在一定的困难
大数据库支持存在一定的困难,需要做单机多实例

复制功能对比

MySQL与 PostgreSQL 数据库功能对比

 

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

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

MySQL支持以下类型:

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

主要功能对比

查询相关功能对比

MySQL与 PostgreSQL 数据库功能对比

 

表的功能支持

MySQL与 PostgreSQL 数据库功能对比

 

架构功能对比

MySQL与 PostgreSQL 数据库功能对比

 

视图表功能对比

MySQL与 PostgreSQL 数据库功能对比

 

加密使用功能对比

MySQL与 PostgreSQL 数据库功能对比

 

后记

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



Tags:PostgreSQL   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
前言JDBC访问Postgresql的jsonb类型字段当然可以使用Postgresql jdbc驱动中提供的PGobject,但是这样在需要兼容多种数据库的系统开发中显得不那么通用,需要特殊处理。本文介绍...【详细内容】
2021-12-23  Tags: PostgreSQL  点击:(13)  评论:(0)  加入收藏
如果您的系统依赖PostgreSQL数据库并且您正在寻找HA的集群解决方案,我们希望提前告知您这是一项复杂的任务,但并非不可能实现。我们将讨论一些解决方案,您可以从中选择对您的容...【详细内容】
2021-03-10  Tags: PostgreSQL  点击:(286)  评论:(0)  加入收藏
生命不止,继续 Go go go !!!之前关于golang操作数据库的博客:Go实战–go语言操作MySQL数据库(go-sql-driver/mysql)Go实战–go语言操作sqlite数据库(The way to go)...【详细内容】
2021-01-05  Tags: PostgreSQL  点击:(196)  评论:(0)  加入收藏
无论你需要的东西简单(如一个购物清单)亦或复杂(如色卡生成器) ,PostgreSQL 命令都能使它变得容易起来。-- Greg Pittman(作者) 在 PostgreSQL 入门 一文中, 我解释了如何安装、设...【详细内容】
2020-12-18  Tags: PostgreSQL  点击:(156)  评论:(0)  加入收藏
2020 年 5 月,我们与 OnGres 合作,对 GitLab 上的 Postgres 集群进行版本大更新,从 9.6 版本升级到 11 版本。升级全部在维护窗口内运行,没有丝毫差错;更新中所有涉及的内容、计...【详细内容】
2020-10-16  Tags: PostgreSQL  点击:(114)  评论:(0)  加入收藏
Linux是一款免费开源的操作系统,由于其自由、开放、安全、稳定等诸多特点,已被各大IT公司广泛地应用于服务器和嵌入式设备中。由于数据存储的需要,Linux操作系统需要搭配一套性...【详细内容】
2020-09-03  Tags: PostgreSQL  点击:(86)  评论:(0)  加入收藏
对于POSTGRESQL 到底使用了多少内存,大部分的使用方法都是进入到POSTGRESQL 中进行查看,今天我们来分享从PostgreSQL 外部来查看内存的方式方法。本次主要使用的命令是ps 命令...【详细内容】
2020-07-29  Tags: PostgreSQL  点击:(142)  评论:(0)  加入收藏
概述postgresql自带提供了一款轻量级的压力测试工具:pgbench ,可自行编写脚本,按自己的需求对数据库进行性能压力测试。这个工具是作者Greg Smith在使用原生pgbench过程中,发现...【详细内容】
2020-06-24  Tags: PostgreSQL  点击:(159)  评论:(0)  加入收藏
安装、设置、创建和开始使用 PostgreSQL 数据库。-- Greg Pittman(作者)每个人或许都有需要在数据库中保存的东西。即使你执着于使用纸质文件或电子文件,它们也会变得很麻烦。...【详细内容】
2020-01-07  Tags: PostgreSQL  点击:(83)  评论:(0)  加入收藏
官方文档二进制安装和启动:https: //www.postgresql.org /download/linux/redhat/源码安装和启动:https:/ /www.postgresql.org/docs/11/install-procedure.htmlhttps:/ /www....【详细内容】
2020-01-07  Tags: PostgreSQL  点击:(132)  评论:(0)  加入收藏
▌简易百科推荐
作者:雷文霆 爱可生华东交付服务部 DBA 成员,主要负责Mysql故障处理及相关技术支持。爱好看书,电影。座右铭,每一个不曾起舞的日子,都是对生命的辜负。 本文来源:原创投稿 *爱可生...【详细内容】
2021-12-24  爱可生    Tags:MySQL   点击:(7)  评论:(0)  加入收藏
生成间隙(gap)锁、临键(next-key)锁的前提条件 是在 RR 隔离级别下。有关Mysql记录锁、间隙(gap)锁、临键锁(next-key)锁的一些理论知识之前有写过,详细内容可以看这篇文章...【详细内容】
2021-12-14  python数据分析    Tags:MySQL记录锁   点击:(18)  评论:(0)  加入收藏
binlog 基本认识 MySQL的二进制日志可以说是MySQL最重要的日志了,它记录了所有的DDL和DML(除了数据查询语句)语句,以事件形式记录,还包含语句所执行的消耗的时间,MySQL的二...【详细内容】
2021-12-14  linux上的码农    Tags:mysql   点击:(13)  评论:(0)  加入收藏
为查询优化你的查询 大多数的MySQL服务器都开启了查询缓存。这是提高性最有效的方法之一,而且这是被MySQL的数据库引擎处理的。当有很多相同的查询被执行了多次的时候,这些查...【详细内容】
2021-12-09  元宇宙iwemeta    Tags:mysql   点击:(15)  评论:(0)  加入收藏
测试的目的和原因,公司有很多程序员,每个程序员对数据库和表结构都有自己的理解。而且每个程序员的理解往往是以效率考虑。既然都是为了效率考虑,那么我就来测试一下究竟哪种使...【详细内容】
2021-12-08  吴彬的分享    Tags:Mysql数据库   点击:(14)  评论:(0)  加入收藏
当你们考虑项目并发的时候,我在部署环境,当你们在纠结使用ArrayList还是LinkedArrayList的时候,我还是在部署环境。所以啊,技术不止境,我在部环境。今天这篇文章缕一下在同一台服...【详细内容】
2021-12-08  秃头码哥    Tags:MySQL数据库   点击:(17)  评论:(0)  加入收藏
对于数据分析来说,MySQL使用最多的是查询,比如对数据进行排序、分组、去重、汇总及字符串匹配等,如果查询的数据涉及多个表,还需要要对表进行连接,本文就来说说MySQL中常用的查询...【详细内容】
2021-12-06  笨鸟学数据分析    Tags:MySQL   点击:(21)  评论:(0)  加入收藏
在学习SQL语句之前,首先需要区分几个概念,我们常说的数据库是指数据库软件,例如MySQL、Oracle、SQL Server等,而本文提到的数据库是指数据库软件中的一个个用于存储数据的容器。...【详细内容】
2021-11-24  笨鸟学数据分析    Tags:SQL语句   点击:(23)  评论:(0)  加入收藏
概述以前参加过一个库存系统,由于其业务复杂性,搞了很多个应用来支撑。这样的话一份库存数据就有可能同时有多个应用来修改库存数据。比如说,有定时任务域xx.cron,和SystemA域...【详细内容】
2021-11-05  Java云海    Tags:分布式锁   点击:(31)  评论:(0)  加入收藏
MySQL的进阶查询 一、 按关键字排序 使用ORDERBY语句来实现排序排序可针对一个或多个字段ASC:升序,默认排序方式 【升序是从小到大】DESC:降序 【降序是从大到小】ORDER BY的...【详细内容】
2021-11-05  Java热点    Tags:SQL语句   点击:(28)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条