PostgreSQL与MySQL优劣势比较浅谈

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: PostgreSQL与MySQL优劣势比较浅谈

1 简介

因为公司使用PostgreSQL很长时间了,忙于功能开发未对其PostgreSQL的一些优劣势有所了解,因为开发代码的话使用mybatis感知不出底层使用的数据库,开发的代码也没有任何变化,所以没有深入了解其底层PostgreSQL,而过去一直使用mysql的话对于底层原理基本数值包括一系列算法。那么对于postgresql和mysql都是免费且功能强大的开源数据库,很多用户面对这两个库都会有一个问题,那就是哪一个才是最好的开源数据库,MySQL还是PostgreSQL呢?该选择哪一个开源数据库呢?

6b999c572ae145dda2d1d95bded82216.png



2 postgresql比mysql强大在那些方面

● PostgreSQL 比MySQL更严格地遵守 SQL 标准。


● PostgreSQL 比 MySQL 更好地处理并发性:


Postgres 实现没有读锁的多版本并发控制 (MVCC)

Postgres 支持可以使用多个 CPU/内核的并行查询计划

Postgres 可以以非阻塞方式创建索引(通过 CREATE INDEX CONCURRENTLY 语法),它可以创建部分索引


● PostgreSQL 比MySQL具有更好的数据一致性


Mysql和Postgresql对编程语言的支持程语言的支持对比


b7b2898838fd46ea8a903fd7ab63df36.png

3 PostgreSQL 为什么在国内没有MySQL流行

对比最新版本的MySQL 和 PostgreSQL, PostgreSQL的性能实际上要更强大一些, 但之所以没有MySQL流行主要还是历史原因,说白了就是出来的晚,人家先用mysql的也不着急换


● MySQL使用起来更简单,在Windows平台上安装比较容易。早期的PostgreSQL没有提供Windows平台的版本, 需要自己编译


● 学习MySQL更加容易, 开箱即用,以root用户连接非常简单, 但是配置PostgreSQL、创建用户等等操作比MySQL要复杂


● MySQL始终有公司背书,创建了社区和配套产品的生态系统,无论是在线文档,还是论坛都比Postgre SQL丰富


4 postgresql比mysql一些主要区别

● 数据类型:PostgreSQL支持更多的数据类型,例如数组,json,hstore等,而MySQL则支持空间数据类型(GIS)。


● 扩展性:PostgreSQL相比MySQL具有更强的扩展性,支持自定义数据类型,函数和存储过程等。它还提供了一些高级功能,如异步复制,流复制,热备等。


● ACID:PostgreSQL具有更严格的ACID(原子性,一致性,隔离性和持久性)兼容性。在默认情况下,PostgreSQL使用更为严格的隔离级别,这有助于保证数据的一致性和完整性。MySQL默认使用更低的隔离级别。


● 性能:MySQL比PostgreSQL更适用于大型的数据集,因为它的性能更好,特别是在读写和并发方面。而PostgreSQL在处理复杂的查询和更大数据集方面的性能表现更优秀。


● 开源协议:MySQL的开源协议是GPL(通用公共许可证),这意味着对MySQL进行修改的衍生产品也必须使用同一协议进行发布。而PostgreSQL的开源协议是BSD,这意味着PostgreSQL可以被商业软件使用,并且修改后的代码可以私有化。


● 跨平台支持:MySQL支持更多的操作系统,如Windows,Linux,macOS,FreeBSD等。PostgreSQL虽然也支持这些操作系统,但它的最初目标是在UNIX操作系统上运行。


总的来说,PG更适合复杂的数据结构、高级应用和大规模数据集,而MySQL更适合简单的Web应用和小规模数据集。但这并不是绝对的规则,因为两种数据库都可以用于各种类型的应用程序。


5 postgresql比mysql特征比较


4f3de364aee548e1b07dbafe2290b531.png

5.1 MariaDB的主要特点

MariaDB具有使其成为出色数据库的多项功能,包括其广泛的存储引擎选择、线程池、SQL兼容性和并行查询执行。


以下是重点:

存储引擎:使MariaDB脱颖而出的特性之一是可供选择的各种存储引擎。PBXT、XtraDB、Maria和FederatedX是一些可行的引擎选项,可以根据您的要求进行定制。它还包含InnoDB,这是一种以平衡高可靠性和高性能而闻名的通用存储引擎。


线程池:线程池是代表应用程序有效执行异步回调的工作线程的集合。当发出请求时,MariaDB可以简单地获取一个先前创建的线程,该线程已经在池中。这节省了创建线程所花费的时间,并提供了线程周期开销的解决方案,允许查询运行得更快并返回更快的结果。


SQL兼容性: MariaDB通过客户端程序(例如mysqldump、mysqladmin)和插件(例如审计插件)提供对大多数SQL语句、变量、定义和函数的支持。开发人员还可以利用MariaDB中的JSON函数、窗口函数和公用表表达式 (CTE)。


虚拟列:对虚拟列的支持是MariaDB的主要特性之一,可用于在数据库级别执行计算。当多个App访问一列时,用户不必在每个App中单独编写计算;数据库代表他们执行此操作。

并行查询执行:从10.0版本开始,您可以同时执行多个查询而不会降低性能,从而加快任务执行速度。


5.2 PostgreSQL的主要特点

除了开源之外,PostgreSQL还拥有多种功能。分区、负载平衡和连接池都与PostgreSQL一起工作,使其在同时代产品中具有相当大的优势。


以下是PostgreSQL的一些显着特性的列表:


支持JSON数据:查询和存储JSON的能力使PostgreSQL也可以运行NoSQL工作负载。如果您正在设计一个数据库来存储来自多个传感器的数据,并且您不确定支持传感器所需的特定列,您可以构建一个表,其中一个列遵循JSON格式来存储不断变化或非结构化的数据。

强大的扩展: PostgreSQL拥有令人印象深刻的功能集,包括时间点恢复、多版本并发控制 (MVCC)、表空间、精细访问控制、预写日志记录和在线/热备份。PostgreSQL还可以区分大小写、排序和格式化。它在可以管理的数据量和可以容纳的同时用户数量方面都具有高度可扩展性。

数据更新:联合的多种形式,结合复制,为几乎任何类型的数据系统提供推送和拉取技术。这些可以组合成不同的配置来桥接数据库存储解决方案,而不需要ELT/ETL处理包。数据根本不会移出源系统,这意味着数据始终是最新的。

测试驱动开发: PostgreSQL遵循测试驱动开发,每个bug都经过测试,编写代码以满足测试。这些测试是集成的,因此错误不会在PostgreSQL的未来版本中再次出现。只有当所有回归测试用例都通过时,才会发布PostgreSQL的新更新。


6 总结

暂时先总结这么多我能知道的,之后的话遇到一些瓶颈再去思考,因为pgsql对于纯开发者来说没有什么学习成本的预算会一种sql就会用。两种最广泛使用的关系型数据库管理系统 PostgreSQL和MySQL既有相似之处,也有不同之处。如果你需要一个用于Web应用程序的,高安全性的关系型数据库管理系统,或者想要构建一个活跃用户超过数百万的面向消费者的app,那么MySQL将适合您的项目。如果你的需求围绕复杂的程序,复杂的设计,集成和数据完整性、事务支持,而不是在高速,那么,PostgreSQL将会是你项目理想的选择。不过国内MySQL占据着主流,社区里关于MySQL的优化和案例很多,PostgreSQL就很少,如果有PostgreSQL的小伙伴可以来分享一些。


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2月前
|
存储 关系型数据库 MySQL
一个项目用5款数据库?MySQL、PostgreSQL、ClickHouse、MongoDB区别,适用场景
一个项目用5款数据库?MySQL、PostgreSQL、ClickHouse、MongoDB——特点、性能、扩展性、安全性、适用场景比较
|
3月前
|
NoSQL 关系型数据库 MySQL
微服务架构下的数据库选择:MySQL、PostgreSQL 还是 NoSQL?
在微服务架构中,数据库的选择至关重要。不同类型的数据库适用于不同的需求和场景。在本文章中,我们将深入探讨传统的关系型数据库(如 MySQL 和 PostgreSQL)与现代 NoSQL 数据库的优劣势,并分析在微服务架构下的最佳实践。
|
1月前
|
存储 关系型数据库 MySQL
MySQL vs. PostgreSQL:选择适合你的开源数据库
在众多开源数据库中,MySQL和PostgreSQL无疑是最受欢迎的两个。它们都有着强大的功能、广泛的社区支持和丰富的生态系统。然而,它们在设计理念、性能特点、功能特性等方面存在着显著的差异。本文将从这三个方面对MySQL和PostgreSQL进行比较,以帮助您选择更适合您需求的开源数据库。
156 4
|
1月前
|
关系型数据库 MySQL PostgreSQL
postgresql和mysql中的limit使用方法
postgresql和mysql中的limit使用方法
52 1
|
3月前
|
Oracle NoSQL 关系型数据库
主流数据库对比:MySQL、PostgreSQL、Oracle和Redis的优缺点分析
主流数据库对比:MySQL、PostgreSQL、Oracle和Redis的优缺点分析
583 2
|
2月前
|
存储 关系型数据库 MySQL
四种数据库对比MySQL、PostgreSQL、ClickHouse、MongoDB——特点、性能、扩展性、安全性、适用场景
四种数据库对比 MySQL、PostgreSQL、ClickHouse、MongoDB——特点、性能、扩展性、安全性、适用场景
|
4月前
|
SQL 关系型数据库 MySQL
SQL Server、MySQL、PostgreSQL:主流数据库SQL语法异同比较——深入探讨数据类型、分页查询、表创建与数据插入、函数和索引等关键语法差异,为跨数据库开发提供实用指导
【8月更文挑战第31天】SQL Server、MySQL和PostgreSQL是当今最流行的关系型数据库管理系统,均使用SQL作为查询语言,但在语法和功能实现上存在差异。本文将比较它们在数据类型、分页查询、创建和插入数据以及函数和索引等方面的异同,帮助开发者更好地理解和使用这些数据库。尽管它们共用SQL语言,但每个系统都有独特的语法规则,了解这些差异有助于提升开发效率和项目成功率。
473 0
|
8天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
71 15
|
2天前
|
SQL 关系型数据库 MySQL
数据库数据恢复—Mysql数据库表记录丢失的数据恢复方案
Mysql数据库故障: Mysql数据库表记录丢失。 Mysql数据库故障表现: 1、Mysql数据库表中无任何数据或只有部分数据。 2、客户端无法查询到完整的信息。
|
9天前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。