0

0

postgresql不同隔离级别下的锁行为_postgresql隔离级别对比

舞夢輝影

舞夢輝影

发布时间:2025-11-21 21:29:06

|

189人浏览过

|

来源于php中文网

原创

PostgreSQL支持读已提交、可重复读和串行化三种事务隔离级别,分别适用于不同并发场景;读已提交为默认级别,允许非可重复读和幻读,SELECT不加锁,写操作加行级排他锁;可重复读通过快照避免不可重复读和幻读,依赖MVCC和写冲突检测,可能因冲突失败;串行化基于SSI技术防止串行化异常,需重试事务以保证强一致性;隔离级别越高,一致性越强但性能开销越大,应用需根据需求权衡选择。

postgresql不同隔离级别下的锁行为_postgresql隔离级别对比

PostgreSQL 的事务隔离级别决定了事务之间如何相互影响,尤其是在并发访问相同数据时的可见性和锁行为。PostgreSQL 支持三种标准隔离级别:读已提交(Read Committed)、可重复读(Repeatable Read)和串行化(Serializable)。每种级别在锁机制和并发控制上表现不同,直接影响应用的性能与一致性。

1. 读已提交(Read Committed)

这是 PostgreSQL 的默认隔离级别,适用于大多数常规业务场景。

说明:
  • 一个事务中每次 SELECT 查询都会看到在该查询开始前已提交的数据。
  • 同一事务内的多次查询可能看到不同的结果(非可重复读)。
  • 写操作(UPDATE、DELETE)会获取行级排他锁,防止其他事务修改同一行。
锁行为特点:
  • SELECT 不加共享锁(除非显式使用 FOR SHARE/UPDATE)。
  • UPDATE 和 DELETE 在匹配的行上加行级排他锁(Exclusive Lock),并持有到事务结束。
  • INSERT 不会对已有行加锁,但可能触发唯一约束检查时产生锁竞争。
  • 可能发生“幻读”(Phantom Read),即两次执行相同条件的查询,返回不同数量的行。

2. 可重复读(Repeatable Read)

该级别通过快照机制保证事务内读取的一致性,避免了不可重复读和幻读。

歌者PPT
歌者PPT

歌者PPT,AI 写 PPT 永久免费

下载
说明:
  • 事务启动时建立一个快照,整个事务期间都基于这个快照读取数据。
  • 即使其他事务提交了更改,当前事务也看不到这些变化。
锁行为特点:
  • 普通 SELECT 仍不加锁,依赖 MVCC 实现一致性。
  • UPDATE 和 DELETE 会尝试锁定目标行;如果发现目标行已被修改(由其他事务提交),则事务会失败并报错“不能序列化访问”,提示存在冲突。
  • 系统通过检测写-写冲突来维护可重复性,而不是长时间持有锁
  • 虽然称为“可重复读”,但在 PostgreSQL 中实际行为接近“快照隔离”(Snapshot Isolation)。

3. 串行化(Serializable)

最高隔离级别,确保事务并发执行的效果等价于串行执行。

说明:
  • 基于可重复读的快照机制,进一步引入“串行化冲突检测”机制。
  • PostgreSQL 使用 SSI(Serializable Snapshot Isolation)技术,在运行时分析事务依赖图,预防危险结构。
锁行为特点:
  • 读操作不加传统锁,仍依赖 MVCC 快照。
  • 系统后台跟踪读-写和写-写依赖关系。
  • 当检测到可能导致串行化异常的情况时,会选择一个事务回滚,并提示错误:“could not serialize access due to concurrent update”。
  • 开发者需捕获此类异常并重试事务。
  • 没有显式的表锁或行锁用于阻塞读,而是通过逻辑冲突判断实现隔离。

隔离级别对比总结

特性 读已提交 可重复读 串行化
是否允许脏读
是否允许不可重复读
是否允许幻读
SELECT 是否加锁 否(除非显式指定)
UPDATE/DELETE 锁类型 行级排他锁 行级锁 + 冲突检测 行级锁 + SSI 检测
自动回滚可能性 有(写冲突) 有(串行化异常)
适用场景 一般Web应用、高并发读写 需要一致快照的报表 强一致性要求金融系统

基本上就这些。选择合适的隔离级别要权衡一致性需求与性能开销。多数情况下,默认的“读已提交”足够用;若需避免幻读且能处理重试逻辑,“串行化”是最安全的选择。理解各级别的锁与MVCC协作方式,有助于设计更健壮的数据库交互逻辑。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据库Delete用法
数据库Delete用法

数据库Delete用法:1、删除单条记录;2、删除多条记录;3、删除所有记录;4、删除特定条件的记录。更多关于数据库Delete的内容,大家可以访问下面的文章。

287

2023.11.13

drop和delete的区别
drop和delete的区别

drop和delete的区别:1、功能与用途;2、操作对象;3、可逆性;4、空间释放;5、执行速度与效率;6、与其他命令的交互;7、影响的持久性;8、语法和执行;9、触发器与约束;10、事务处理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

222

2023.12.29

postgresql常用命令
postgresql常用命令

postgresql常用命令psql、createdb、dropdb、createuser、dropuser、l、c、dt、d table_name、du、i file_name、e和q等。本专题为大家提供postgresql相关的文章、下载、课程内容,供大家免费下载体验。

164

2023.10.10

常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1007

2023.11.02

postgresql常用命令有哪些
postgresql常用命令有哪些

postgresql常用命令psql、createdb、dropdb、createuser、dropuser、l、c、dt、d table_name、du、i file_name、e和q等。更详细的postgresql常用命令,大家可以访问下面的文章。

214

2023.11.16

postgresql常用命令介绍
postgresql常用命令介绍

postgresql常用命令有l、d、d5、di、ds、dv、df、dn、db、dg、dp、c、pset、show search_path、ALTER TABLE、INSERT INTO、UPDATE、DELETE FROM、SELECT等。想了解更多postgresql的相关内容,可以阅读本专题下面的文章。

280

2023.11.20

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

229

2026.02.12

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

387

2023.06.29

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 4.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号