PostgreSQL 也很强大,为何在中国大陆,MySQL 成为主流,PostgreSQL 屈居二线呢?

本文主要是介绍PostgreSQL 也很强大,为何在中国大陆,MySQL 成为主流,PostgreSQL 屈居二线呢?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题:

  • PostgreSQL 也很强大,为何在中国大陆,MySQL 成为主流,PostgreSQL 屈居二线呢?
  • PostgreSQL 能否替代 MySQL?

当我们讨论为何 MySQL 在中国大陆成为主流而 PostgreSQL 屈居二线时,
我们其实在剖析的是一段技术演进与市场需求相互作用的历史。

首先,我们得承认每种技术都有其诞生和发展的背景。

起初,MySQL 更像是一种轻量级的解决方案,它提供了足以满足基本需求的关系数据库功能。
它的诞生正赶上了互联网的初期波潮,那时候,很多互联网初创企业都需要一种简单、易用且能够迅速部署的数据库系统来支持它们的业务,
而 MySQL 恰好符合这些需求。

MySQL 的优势在于其简单性和性能。
很多早期的应用并不需要复杂的事务管理或者高级的数据库功能;
它们更多地需要的是快速的读写能力和易于水平扩展的架构。MySQL 的 MyISAM 存储引擎在当时提供了非常高效的读取速度,
这使得 MySQL 在处理大量的简单查询时非常迅速。

&nbsp

举个例子来说,如果你的应用是一个内容发布系统,访问量非常大,但事务处理并不复杂,
如多数内容都是读取操作(例如新闻网站或博客平台),那么 MySQL 就很可能是一个合适的选择。
因为在这种场景下,你更关心的可能是如何快速地向用户展示内容,而不是如何处理复杂的数据关系或事务。

随着业务的发展,人们开始逐渐意识到 MySQL 除了简单性能外,也需要强化其事务处理的能力。
这时候,InnoDB 存储引擎开始受到青睐,因为它支持ACID事务,提供了行级锁定(row-level locking)和外键约束,
这些都是企业级应用所需的特性。

&nbsp

然而,PostgreSQL 一直以其作为“最先进的开源数据库”自居,它在事务处理、数据一致性和高级特性上拥有非常强大的能力。
比如,它的MVCC(多版本并发控制)为数据库提供了高级的事务隔离级别,
这对于需要处理复杂查询和保持强数据一致性的金融或者企业级应用来说是非常关键的。

以金融业为例,如果一个银行需要处理成百上千的交易,这些交易之间可能存在复杂的关系,需要确保数据的一致性和安全性。
在这种情况下,PostgreSQL 的高级事务控制、强数据一致性保障和丰富的数据类型(例如,对金融产品进行建模时可能会用到的范围类型或自定义复合类型)就显得尤为重要了。
这可以保证在多用户并发操作下,数据的完整性不会受到威胁。

&nbsp

但 PostgreSQL 在早期有其不足之处,尤其是在易用性和运维上。例如,它长期使用的是多进程模型,
这在管理大量连接时的资源开销要高于 MySQL 的多线程模型。并且,直到近些年 PostgreSQL 才引入了逻辑复制(logical replication),
而 MySQL 在这方面走在了前面。

当然,随着时间的推移,两者都发生了演变。MySQL 增添了诸如存储过程、触发器、视图等高级功能,
而 PostgreSQL 也变得更加易用,新增了对逻辑复制的支持,改善了性能和易用性。

在决定是否能够替换 MySQL时 ,PostgreSQL 需要面对的不仅仅是技术挑战,还有市场和生态的挑战。
MySQL 的普及为其构建了强大的社区支持和丰富的周边工具,而这些对于企业来说是一个不容忽视的优势。
另外,因为很多人才市场上的数据库管理员和开发者更加熟悉 MySQL,这也促成了它的主流地位。

推荐几个学习 MySQL 教程文章

  • 01、MySQL 简介
  • 02、MySQL 管理
  • 03、MySQL 创建连接
  • 04、MySQL 获取数据库列表
  • 05、MySQL 创建数据库
  • 06、MySQL 数据类型
  • 07、MySQL 创建数据表
  • 08、MySQL 插入数据
  • 09、MySQL SELECT FROM 查询数据
  • 10、MySQL WHERE 子句有条件的查询数据
  • 11、MySQL UPDATE 更新数据
  • 12、MySQL DELETE FROM 语句删除数据
  • 13、MySQL JOIN 进行多表查询
  • 14、MySQL 数据库事务
  • 15、MySQL 索引

小结:

PostgreSQL 是否能够扛起大梁并不是一个技术层面能够简单回答的问题。
它涉及到对现有业务的影响、团队的技术栈熟悉度、以及维护和运营的成本等一系列复杂因素。
如果你的应用场景能够从 PostgreSQL 的高级特性中受益,同时你的团队对它也有足够了解,那么它绝对是一个可行的选择。
不过,在大多数情况下,企业可能会因为种种原因继续选择 MySQL,这是市场和技术共同作用的结果。

求一键三连:点赞、分享、收藏

点赞对我真的非常重要!在线求赞,加个关注我会非常感激!@小郑说编程

这篇关于PostgreSQL 也很强大,为何在中国大陆,MySQL 成为主流,PostgreSQL 屈居二线呢?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/676455

相关文章

Linux lvm实例之如何创建一个专用于MySQL数据存储的LVM卷组

《Linuxlvm实例之如何创建一个专用于MySQL数据存储的LVM卷组》:本文主要介绍使用Linux创建一个专用于MySQL数据存储的LVM卷组的实例,具有很好的参考价值,希望对大家有所帮助,... 目录在Centos 7上创建卷China编程组并配置mysql数据目录1. 检查现有磁盘2. 创建物理卷3. 创

MySQL 事务的概念及ACID属性和使用详解

《MySQL事务的概念及ACID属性和使用详解》MySQL通过多线程实现存储工作,因此在并发访问场景中,事务确保了数据操作的一致性和可靠性,下面通过本文给大家介绍MySQL事务的概念及ACID属性和... 目录一、什么是事务二、事务的属性及使用2.1 事务的 ACID 属性2.2 为什么存在事务2.3 事务

Mysql中的用户管理实践

《Mysql中的用户管理实践》:本文主要介绍Mysql中的用户管理实践,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录13. 用户管理13.1 用户 13.1.1 用户信息 13.1.2 创建用户 13.1.3 删除用户 13.1.4 修改用户

MySQL查看表的最后一个ID的常见方法

《MySQL查看表的最后一个ID的常见方法》在使用MySQL数据库时,我们经常会遇到需要查看表中最后一个id值的场景,无论是为了调试、数据分析还是其他用途,了解如何快速获取最后一个id都是非常实用的技... 目录背景介绍方法一:使用MAX()函数示例代码解释适用场景方法二:按id降序排序并取第一条示例代码解

Python+PyQt5实现MySQL数据库备份神器

《Python+PyQt5实现MySQL数据库备份神器》在数据库管理工作中,定期备份是确保数据安全的重要措施,本文将介绍如何使用Python+PyQt5开发一个高颜值,多功能的MySQL数据库备份工具... 目录概述功能特性核心功能矩阵特色功能界面展示主界面设计动态效果演示使用教程环境准备操作流程代码深度解

如何清理MySQL中的binlog问题

《如何清理MySQL中的binlog问题》:本文主要介绍清理MySQL中的binlog问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目http://www.chinasem.cn录清理mysql中的binlog1.查看binlog过期时间2. 修改binlog过期

MySQL基本查询示例总结

《MySQL基本查询示例总结》:本文主要介绍MySQL基本查询示例总结,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Create插入替换Retrieve(读取)select(确定列)where条件(确定行)null查询order by语句li

查看MySql主从同步的偏移量方式

《查看MySql主从同步的偏移量方式》:本文主要介绍查看MySql主从同步的偏移量方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 1.mysql的主从同步方案mysqlphp为了在实现读写分离,主库写,从库读mysql的同步方案主要是通过从库读取主库的binl

MySQL表空间结构详解表空间到段页操作

《MySQL表空间结构详解表空间到段页操作》在MySQL架构和存储引擎专题中介绍了使用不同存储引擎创建表时生成的表空间数据文件,在本章节主要介绍使用InnoDB存储引擎创建表时生成的表空间数据文件,对... 目录️‍一、什么是表空间结构1.1 表空间与表空间文件的关系是什么?️‍二、用户数据在表空间中是怎么

Java JSQLParser解析SQL的使用指南

《JavaJSQLParser解析SQL的使用指南》JSQLParser是一个Java语言的SQL语句解析工具,可以将SQL语句解析成为Java类的层次结构,还支持改写SQL,下面我们就来看看它的具... 目录一、引言二、jsQLParser常见类2.1 Class Diagram2.2 Statement