news 2025/12/19 18:30:26

postgrsql和mysql区别?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
postgrsql和mysql区别?

一、一句话核心区别(先给结论)

MySQL 更偏“快、简单、工程化”
PostgreSQL 更偏“严谨、强大、学术 + 企业级”

如果只记一句话:

  • MySQL = 高并发 OLTP、互联网业务

  • PostgreSQL = 复杂查询、强一致性、复杂数据结构


二、架构与内核差异(本质区别)

1️⃣ 并发控制(非常关键)

🔹 MySQL(InnoDB)

  • 使用MVCC + Undo Log

  • 更新数据时:

    • 旧版本写入 Undo Log

    • 新数据直接写回表

  • 优点:实现简单、性能好

  • 缺点:

    • Undo Log 膨胀

    • 长事务影响明显

🔹 PostgreSQL

  • 真正的 MVCC(多版本存储)

  • 更新数据时:

    • 不覆盖原行

    • 新行插入一条新记录

  • 优点:

    • 读写几乎不阻塞

    • 强一致性

  • 缺点:

    • 表会“变胖”

    • 需要 VACUUM 回收

👉结论

  • 并发读写复杂场景:PG 更稳

  • 简单高并发:MySQL 更轻


2️⃣ 锁机制

对比项MySQLPostgreSQL
行锁
表锁
间隙锁✔(防幻读)
乐观并发一般

📌MySQL 的间隙锁在高并发下容易“锁住一片数据”,
PG 不存在这个问题。


三、SQL 能力 & 标准支持(PG 明显更强)

1️⃣ SQL 标准支持

能力MySQLPostgreSQL
SQL 标准一般⭐⭐⭐⭐⭐
CTE(WITH)✔(更强)
Window Function✔(更全)
子查询优化一般很强

👉复杂 SQL、报表、分析类查询 → PG 完胜


2️⃣ 数据类型(PG 碾压)

PostgreSQL 支持:

  • JSON / JSONB(可索引)

  • ARRAY

  • HSTORE

  • UUID

  • ENUM

  • RANGE

  • GEOMETRY(GIS)

MySQL:

  • JSON(功能较弱)

  • 基本类型为主

📌PG 可以当“半 NoSQL 数据库”用


3️⃣ 索引类型(PG 极强)

索引类型MySQLPostgreSQL
B-Tree
Hash⚠️(基本不用)
GIN
GiST
BRIN
全文索引一般

👉 搜索、JSON、数组、地理数据 →PG 无敌


四、事务与一致性(PG 更“严格”)

1️⃣ 事务隔离级别

隔离级别MySQLPostgreSQL
Read Uncommitted❌(等同 RC)
Read Committed
Repeatable Read✔(默认)
Serializable⚠️✔(真正)

📌PG 的 Serializable 是严格可串行化
MySQL 更偏工程实现。


2️⃣ 约束 & 数据完整性

特性MySQLPostgreSQL
外键⚠️(不常用)
Check 约束8.0 才完善
约束严格性一般非常严格

👉金融、账务系统更偏向 PG


五、性能对比(不要被“谁更快”误导)

1️⃣ 简单 CRUD

  • MySQL 更快

  • 配置简单

  • 资源消耗低

2️⃣ 复杂查询 / JOIN / 子查询

  • PostgreSQL 更快

  • 优化器更智能

3️⃣ 高并发写入

  • MySQL:需要精细索引设计

  • PG:写多版本,稳定但需要维护

👉性能不是绝对,看业务模型


六、扩展能力(PG 非常强)

PostgreSQL

  • 支持自定义函数(C、Python、JavaScript)

  • 插件生态:

    • PostGIS(地理信息)

    • TimescaleDB(时序)

    • Citus(分布式)

  • 可扩展性极强

MySQL

  • 插件较少

  • 主要靠中间件(分库分表)


七、主从复制 & 高可用

能力MySQLPostgreSQL
主从复制成熟成熟
读写分离非常成熟成熟
分库分表中间件成熟原生弱
云支持极好很好

👉互联网公司 MySQL 生态优势明显


八、典型使用场景(非常重要)

✅ 选 MySQL 的场景

  • 电商、用户系统

  • 高并发 CRUD

  • 微服务后台

  • 互联网业务

✅ 选 PostgreSQL 的场景

  • BI / 报表 / 数据分析

  • 金融、账务、风控

  • 复杂查询

  • JSON / 地理 / 时序数据

  • 强一致性要求


九、面试高频总结版(背这个就行)

MySQL 更偏工程化、高并发、简单模型
PostgreSQL 更偏学术化、强一致性、复杂数据处理

面试官常追问的点:

  • PG 的 MVCC 和 MySQL 的区别

  • PG 为什么不需要间隙锁

  • PG 的 JSONB 索引

  • 为什么金融系统更偏 PG

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/18 2:02:30

分析Mifare Ultralight C 3DES认证:Proxmark3实战指南

分析Mifare Ultralight C 3DES认证:Proxmark3实战指南 【免费下载链接】proxmark3 Iceman Fork - Proxmark3 项目地址: https://gitcode.com/GitHub_Trending/pr/proxmark3 还在为Mifare Ultralight C标签的加密通信而困扰?面对3DES认证机制&…

作者头像 李华
网站建设 2025/12/15 4:41:34

kubectl exec 的底层原理

如果你使用 Kubernetes&#xff0c;那么你对 kubectl exec -it <pod-name> -- sh 这个命令一定不会陌生。它是我们调试容器、查看日志或排查问题的“瑞士军刀”。我们通常的理解是&#xff1a;“哦&#xff0c;它是在容器内部启动了一个 shell”。 但这个理解并不完全准确…

作者头像 李华
网站建设 2025/12/15 4:41:32

Flink自定义函数终极指南:如何快速掌握三大核心函数开发

Flink自定义函数终极指南&#xff1a;如何快速掌握三大核心函数开发 【免费下载链接】flink-learning flink learning blog. http://www.54tianzhisheng.cn/ 含 Flink 入门、概念、原理、实战、性能调优、源码解析等内容。涉及 Flink Connector、Metrics、Library、DataStream …

作者头像 李华
网站建设 2025/12/15 4:41:30

Wan2.2视频生成:如何用消费级显卡实现电影级创作体验?

你是否曾经想过&#xff0c;为什么专业级视频生成总是需要昂贵的A100显卡&#xff1f;为什么开源方案在画质和流畅度上总是差强人意&#xff1f;这些问题困扰着无数创作者和开发者&#xff0c;直到Wan2.2的出现彻底改变了这一局面。 【免费下载链接】Wan2.2-TI2V-5B-Diffusers …

作者头像 李华
网站建设 2025/12/13 17:36:02

ioredis终极指南:5分钟掌握Node.js Redis客户端的完整用法

ioredis终极指南&#xff1a;5分钟掌握Node.js Redis客户端的完整用法 【免费下载链接】ioredis 项目地址: https://gitcode.com/gh_mirrors/ior/ioredis 想要在Node.js项目中快速集成Redis吗&#xff1f;ioredis作为最受欢迎的Redis客户端&#xff0c;提供了简单易用的…

作者头像 李华
网站建设 2025/12/13 17:34:10

那个让我熬夜三天的bug,原来OrcaSlicer编译还能这样玩!

那个让我熬夜三天的bug&#xff0c;原来OrcaSlicer编译还能这样玩&#xff01; 【免费下载链接】OrcaSlicer G-code generator for 3D printers (Bambu, Prusa, Voron, VzBot, RatRig, Creality, etc.) 项目地址: https://gitcode.com/GitHub_Trending/orc/OrcaSlicer 你…

作者头像 李华