时代变了,MySQL 早已不是最流行的数据库了
以下文章来源于古时的风筝 ,作者风筝
在StackOverflow 上看到2024年技术趋势,关于数据库的部分,PostgreSQL 是开发人员使用最多的数据库,超过 MySQL 了。虽然在国内好像不是这样。
PostgreSQL 在 2018 年的开发者调查中首次亮相,当时有 33% 的开发者正在使用它。而当年最受欢迎的还是 MySQL,有 59% 的开发者在使用。而六年后的今天,49% 的开发人员使用 PostgreSQL,连续第二年成为最受欢迎的数据库。
PostgreSQL 是什么
PostgreSQL 的历史可以追溯到加利福尼亚大学伯克利分校的 Ingres 项目。1985年,开始了以 post-Ingres 计划为原型进行研发,也就是 Postgres 的最初是版本。
其目的是通过增加最少的功能来完全支持所需要的类型。
这些功能包括类型定义和完整描述数据关系的能力。完整描述数据关系的能力之前虽广为使用但却需要由用户来维护。Postgres的数据库能够"理解"关系,并可以使用一定的规则以自然方式在相关的表中检索信息。
直到 1994年,Postgres95 增加了 SQL 语言解释器,后在1996年更名为 PostgreSQL。
PostgreSQL 和 MySQL 一样,也是完全开源的,也是一个关系型数据库。
作为一个优秀的关系型数据库,PostgreSQL 支持这么多特性,怪不得现在使用的人这么多。
- 支持自定义数据类型和继承,允许用户定义新的类型和基于现有类型的子类型。
- 支持多种编程语言编写的函数,包括 PL/pgSQL、PL/Perl、PL/Python 等。
- 提供了自定义索引方法,包括 B树、哈希表和 GiST 索引。
- 支持多版本并发控制(MVCC),减少了读取锁的依赖,提高了并发性能。
- 支持规则(RULE),允许查询重写,常用于视图操作。
- 内置丰富的数据类型,如任意精度数值、无限制长度文本、几何图元、IP地址、数组、JSON数据、枚举类型和 XML 数据。
- 支持用户定义对象,如索引、操作符、聚合函数、数据域、数据类型转换和会话。
- 支持继承,允许数据表结构和属性从一个“父”表继承。
- 支持关系完整性约束、视图、内外部连接、子查询、事务处理等。
- 支持 SSL 加密连接、二进制/文本大对象存储、在线备份、数据域、表分区、表空间、保存点、时刻点恢复、二阶段提交等。
- 支持 TOAST 技术,用于存储超大属性。
看上去是完全覆盖 MySQL 的功能的,就比如 PostgreSQL 是直接支持数组类型的,而 MySQL 中你就要转一下。
PostgreSQL和MySQL的区别
这两个数据库接的头两把交椅之间有什么区别呢?
数据一致性和事务处理
PostgreSQL 和MySQL 都实现了完整的ACID特性(原子性、一致性、隔离性、持久性),并且采用了多版本并发控制(MVCC)来管理事务。
MySQL的默认存储引擎MyISAM曾经不支持事务,但是现在InnoDB已经成为MySQL的默认引擎,并且支持事务了。
但是其在处理复杂事务时的性能和一致性仍然不如PostgreSQL稳健。
扩展性和灵活性
PostgreSQL 扩展性和灵活性是非常强大的。开发者可以使用PostgreSQL自定义数据类型、操作符、索引方法,甚至编写存储过程和触发器来扩展数据库的功能。
而MySQL虽然也支持一些扩展功能,但相比之下,它的灵活性较为有限。MySQL的设计更注重易用性和性能优化,但这也使得它在处理复杂数据类型和自定义需求时显得有些捉襟见肘。
性能方面
在性能上,MySQL的优势在于其读写性能,尤其是在处理大量简单查询时,MySQL的速度非常快。这使得MySQL成为了许多Web应用的首选,尤其是那些以读取为主的应用。
而PostgreSQL则在处理复杂查询和大数据集时表现优异。PostgreSQL的查询优化器非常强大,它能够对复杂的SQL查询进行优化,确保在高负载下依然保持出色的性能。对于那些需要执行大量数据分析、数据聚合的应用来说,PostgreSQL无疑是更好的选择。
数据库引擎和存储
MySQL最大的特点之一是它支持多种存储引擎,如InnoDB、MyISAM。开发者可以根据需求选择最适合的引擎,例如InnoDB提供了事务支持和外键约束,而MyISAM则在读取性能上更具优势。
而PostgreSQL采用统一的存储架构,所有数据都存储在一个共享的存储引擎中。这种设计保证了数据的一致性和完整性,同时也简化了开发和运维的工作。虽然没有MySQL那样多样的选择,但PostgreSQL凭借其强大的功能和灵活性,依然能够满足大多数应用场景的需求。
PostgreSQL 更受欢迎的原因
看过上面,好像也没有看出PostgreSQL 比 MySQL 强在哪里啊,那为什么却超越了MySQL,成为最受欢迎的数据库了呢?
原因是以下几个方面:
数据完整性和可靠性
PostgreSQL在数据完整性和可靠性方面的优势是它获得青睐的重要原因之一。
PostgreSQL的设计理念一直是优先考虑数据的准确性和完整性,而不是牺牲这些特性来换取性能。这一点对于那些需要高数据一致性的应用来说至关重要,比如金融行业、政府机构和医疗领域。
强大的查询能力
在处理复杂查询时,PostgreSQL的表现远超MySQL。
其优化器可以处理非常复杂的SQL查询,包括子查询、联接和窗口函数等。PostgreSQL还支持丰富的索引类型,如B树、哈希、GiST、GIN、BRIN等,这使得它在大数据集上的查询性能非常出色。
对于需要进行复杂数据分析和实时决策支持的企业来说,PostgreSQL是一个理想的选择。
扩展性和自定义能力
PostgreSQL的扩展能力是它能够脱颖而出的另一个关键因素。开发者可以根据业务需求,对PostgreSQL进行深度定制,添加自定义的数据类型、函数、操作符,甚至是索引方式。
这种灵活性使得PostgreSQL能够适应各种复杂的业务场景,从而赢得了众多企业的青睐。
举个例子,许多使用地理信息系统(GIS)的公司都选择PostgreSQL,因为它可以通过PostGIS扩展,提供强大的空间数据处理能力。
类似地,许多大数据处理和分析系统也选择了PostgreSQL,因为它可以通过自定义扩展来优化查询和数据处理流程。
高标准的SQL兼容性
PostgreSQL一直以来都以严格遵循SQL标准而著称,这使得它在需要与其他数据库系统兼容或迁移数据时非常方便。MySQL虽然在功能上也在不断追赶,但在SQL标准的兼容性上,PostgreSQL依然保持领先。
此外,PostgreSQL还支持丰富的数据类型,包括数组、JSON、XML等,甚至可以存储和查询地理空间数据。对于那些需要处理非结构化数据或复杂数据类型的应用来说,PostgreSQL无疑提供了更多的选择和更大的灵活性。
云原生和大数据支持
随着云计算和大数据技术的快速发展,PostgreSQL的高扩展性和分布式处理能力使其在云原生应用中表现出色。许多云服务提供商,如AWS、Google Cloud和Azure,都提供了托管的PostgreSQL服务,这让开发者可以轻松地将PostgreSQL集成到他们的云应用中。
此外,PostgreSQL还支持分布式数据库和并行查询,这使得它在处理大规模数据集和高并发场景时,依然能够保持良好的性能和稳定性。这一点对于那些需要处理海量数据的互联网公司来说尤为重要。
但是国内云平台还是应用 MySQL 的更多一些。
开源精神和社区支持
PostgreSQL的开源精神和强大的社区支持也是它获得广泛认可的重要原因。与某些开源项目不同,PostgreSQL始终坚持完全开源,没有分割成商业版本和开源版本。这种透明和开放的开发模式吸引了全球无数的开发者和企业用户参与到PostgreSQL的社区中来。
PostgreSQL社区非常活跃,经常发布新的版本和功能,不断提升数据库的性能和稳定性。同时,社区中也有大量的教程、文档和工具可以帮助开发者更快地上手和使用PostgreSQL。
结语
如果你觉得文章很棒,可以转发,评论该文章;如果文章有问题,请留言或私信告诉我,我会在第一时间对内容进行调整,这将会帮助每一位想要学习网络基础的小伙伴,感谢!抱拳!
相关文章:

时代变了,MySQL 早已不是最流行的数据库了
以下文章来源于古时的风筝 ,作者风筝 在StackOverflow 上看到2024年技术趋势,关于数据库的部分,PostgreSQL 是开发人员使用最多的数据库,超过 MySQL 了。虽然在国内好像不是这样。 PostgreSQL 在 2018 年的开发者调查中首次亮相…...

K8S容器实例Pod安装curl-vim-telnet工具
在没有域名的情况下,有时候需要调试接口等需要此工具 安装curl、telnet、vim等 直接使用 apk add curlapk add vimapk add tennet...
代码随想录算法训练营DAY09之动态规划(一)基础题目
理论基础: 如果某一问题有很多重叠子问题,使用动态规划是最有效的。 动态规划中每一个状态一定是由上一个状态推导出来的,这一点就区分于贪心,贪心没有状态推导,而是从局部直接选最优的。 例子: 例如&a…...
线性系统分析
一、定义 (1)叠加性 若 且 则称该系统具有叠加性。 叠加性:系统的一个输入不影响系统对其他输入的响应。 (2)均匀性 若 对任意常数a下式都成立 则称该系统具有均匀性。 均匀性:系统能够保持对输入信号的缩放因子不变。 (3)线性系统 若一个系统同时具有叠加性和…...

Ubuntu 20.04 部署 NET8 Web - Systemd 的方式 达到外网访问的目的
1.Ubuntu服务器环境安装 1.1 增加微软包安装源 wget https://packages.microsoft.com/config/ubuntu/22.04/packages-microsoft-prod.deb -O packages-microsoft-prod.deb sudo dpkg -i packages-microsoft-prod.deb1.2 Install the .NET SDK # 更新本地软件包列表。原理&am…...
线程池(ThreadPool):使用ExecutorService、ThreadPoolExecutor等线程池管理并发任务以及底层实现原理
线程池(ThreadPool)是一种通过预先创建和维护一组线程的机制,用来高效管理并发任务。线程池不仅能减少创建和销毁线程的开销,还能更好地控制并发任务的执行。Java 中提供了多种方式来管理线程池,其中包括 ExecutorServ…...

人力资源数据集分析(二)_随机森林与逻辑回归
数据入口:人力资源分析数据集 - Heywhale.com 数据说明 字段说明EmpID唯一的员工IDAge年龄AgeGroup年龄组Attrition是否离职BusinessTravel出差:很少、频繁、不出差DailyRate日薪Department任职部门:研发部门、销售部门、人力资源部门Dista…...
【30天玩转python】数据库操作
数据库操作 数据库是应用程序中用于存储和管理数据的核心组件。Python 提供了多种与数据库交互的方式,支持不同类型的数据库,包括关系型数据库(如 MySQL、PostgreSQL)和 NoSQL 数据库(如 MongoDB)。在这篇…...

PTT:Point Tree Transformer for Point Cloud Registration 论文解读
目录 一、导言 二、相关工作 1、基于Transformer的点云配准 2、针对点云的局部注意力 三、PTT 1、KPconv提取特征 2、Tree Transformer Encoder 3、Decoder 4、估计姿态 5、损失函数 四、实验 1、对比不同Backbone 2、运行时间对比 3、对比不同PTT方法下RR指标的…...

C++速通LeetCode中等第7题-和为K的子数组(巧用前缀和)
巧用哈希表与前缀和,前缀和差为k的两个序号之间的数组就是满足条件的子数组,用哈希表来存放每个序号的前缀和。 前缀和就是头元素到当前序号子数组元素的和 class Solution { public:int subarraySum(vector<int>& nums, int k) {unordered_…...

【读书笔记-《30天自制操作系统》-23】Day24
本篇内容依然比较简单,主要是优化窗口功能以及开发定时器应用程序。首先是优化窗口的切换功能,实现通过键盘和鼠标切换窗口,然后是实现通过鼠标关闭窗口。接着实现不同窗口输入状态的切换,最后是实现定时器的API与应用程序。 1.…...

XML:DOM4j解析XML
XML简介: 什么是XML:XML 是独立于软件和硬件的信息传输工具。 XML 的设计宗旨是传输数据,而不是显示数据。XML 标签没有被预定义。您需要自行定义标签。XML不会做任何事情,XML被设计用来结构化、存储以及传输信息。 XML可以发明…...
15.5 创建监控控制平面的service
本节重点介绍 : k8s中service的作用和类型创建k8s控制平面的service 给prometheus采集用, 类型clusterIp kube-schedulerkube-controller-managerkube-etcd service的作用 Kubernetes Service定义了这样一种抽象: Service是一种可以访问 Pod逻辑分组…...

【Docker Nexus3】maven 私库
1.部署环境 window 11 x64Docker Desktop 4.34.1 (166053) Docker Engine v27.2.0 1.1.Docker 镜像源 1.1.1.Docker Engine 配置 {"builder": {"features": {"buildkit": true},"gc": {"defaultKeepStorage": "32…...

Docker本地部署Chatbot Ollama搭建AI聊天机器人并实现远程交互
文章目录 前言1. 拉取相关的Docker镜像2. 运行Ollama 镜像3. 运行Chatbot Ollama镜像4. 本地访问5. 群晖安装Cpolar6. 配置公网地址7. 公网访问8. 固定公网地址 前言 本文主要分享如何在群晖NAS本地部署并运行一个基于大语言模型Llama 2的个人本地聊天机器人并结合内网穿透工具…...
MySQL:用户管理
添加用户 create user usernamelocalhost identified by user_password;删除用户 drop user usernamelocalhost;查看所有用户 输入格式 select user,host from mysql.user; 输出 mysql> select user,host from mysql.user; ----------------------------- | user …...

论文《Mixture of Weak Strong Experts on Graphs》笔记
【Mowst 2024 ICLR】论文提出了一种新的图神经网络架构,称为Mixture of weak and strong experts(Mowst),通过将轻量级的多层感知机(MLP)作为弱专家和现成的GNN作为强专家相结合,以处理图中的节…...

【诉讼流程-健身房-违约-私教课-诉讼书提交流程-民事诉讼-自我学习-铺平通往法律的阶梯-讲解(3)】
【诉讼流程-健身房-违约-私教课-诉讼书提交流程-民事诉讼-自我学习-铺平通往法律的阶梯-讲解(3)】 1、前言说明2、流程说明3、现场提交(线下)4、网上提交1-起诉书样例2-起诉书编写(1)原告信息:&…...

数据结构(Day14)
一、学习内容 结构体 概念 引入:定义整数赋值为10 int a10; 定义小数赋值为3.14 float b3.14; 定义5个整数并赋值 int arr[5] {1 , 2 , 3 , 4 ,5}; 定义一个学生并赋值学号姓名成绩 定义一个雪糕并赋值名称产地单价 问题:没有学生、雪糕 数据类型 解决&…...

Paragon NTFS for Mac和Tuxera NTFS for Mac,那么两种工具有什么区别呢?
我们在使用Mac系统读取U盘的过程中往往会遇到一个问题,那就是U盘插进电脑无法显示,或者只能读取不能编辑。出现这种情况的原因就一般是格式错误。 很多小伙伴在解决这种问题的时候会选择使用U盘读写工具,那么哪一种读写工具比较好呢…...
RestClient
什么是RestClient RestClient 是 Elasticsearch 官方提供的 Java 低级 REST 客户端,它允许HTTP与Elasticsearch 集群通信,而无需处理 JSON 序列化/反序列化等底层细节。它是 Elasticsearch Java API 客户端的基础。 RestClient 主要特点 轻量级ÿ…...

【Axure高保真原型】引导弹窗
今天和大家中分享引导弹窗的原型模板,载入页面后,会显示引导弹窗,适用于引导用户使用页面,点击完成后,会显示下一个引导弹窗,直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…...
day52 ResNet18 CBAM
在深度学习的旅程中,我们不断探索如何提升模型的性能。今天,我将分享我在 ResNet18 模型中插入 CBAM(Convolutional Block Attention Module)模块,并采用分阶段微调策略的实践过程。通过这个过程,我不仅提升…...
Auto-Coder使用GPT-4o完成:在用TabPFN这个模型构建一个预测未来3天涨跌的分类任务
通过akshare库,获取股票数据,并生成TabPFN这个模型 可以识别、处理的格式,写一个完整的预处理示例,并构建一个预测未来 3 天股价涨跌的分类任务 用TabPFN这个模型构建一个预测未来 3 天股价涨跌的分类任务,进行预测并输…...
五年级数学知识边界总结思考-下册
目录 一、背景二、过程1.观察物体小学五年级下册“观察物体”知识点详解:由来、作用与意义**一、知识点核心内容****二、知识点的由来:从生活实践到数学抽象****三、知识的作用:解决实际问题的工具****四、学习的意义:培养核心素养…...
【HTML-16】深入理解HTML中的块元素与行内元素
HTML元素根据其显示特性可以分为两大类:块元素(Block-level Elements)和行内元素(Inline Elements)。理解这两者的区别对于构建良好的网页布局至关重要。本文将全面解析这两种元素的特性、区别以及实际应用场景。 1. 块元素(Block-level Elements) 1.1 基本特性 …...
三体问题详解
从物理学角度,三体问题之所以不稳定,是因为三个天体在万有引力作用下相互作用,形成一个非线性耦合系统。我们可以从牛顿经典力学出发,列出具体的运动方程,并说明为何这个系统本质上是混沌的,无法得到一般解…...
LLM基础1_语言模型如何处理文本
基于GitHub项目:https://github.com/datawhalechina/llms-from-scratch-cn 工具介绍 tiktoken:OpenAI开发的专业"分词器" torch:Facebook开发的强力计算引擎,相当于超级计算器 理解词嵌入:给词语画"…...

【论文阅读28】-CNN-BiLSTM-Attention-(2024)
本文把滑坡位移序列拆开、筛优质因子,再用 CNN-BiLSTM-Attention 来动态预测每个子序列,最后重构出总位移,预测效果超越传统模型。 文章目录 1 引言2 方法2.1 位移时间序列加性模型2.2 变分模态分解 (VMD) 具体步骤2.3.1 样本熵(S…...

selenium学习实战【Python爬虫】
selenium学习实战【Python爬虫】 文章目录 selenium学习实战【Python爬虫】一、声明二、学习目标三、安装依赖3.1 安装selenium库3.2 安装浏览器驱动3.2.1 查看Edge版本3.2.2 驱动安装 四、代码讲解4.1 配置浏览器4.2 加载更多4.3 寻找内容4.4 完整代码 五、报告文件爬取5.1 提…...