【PostgreSQL】【第4章】PostgreSQL的事务

1. 事务基础与ACID特性

1.1 事务基本概念
  • 事务:一组相关操作的集合,要么全部成功,要么全部失败。
  • 核心目的 :保证数据操作的原子性一致性
1.2 ACID特性详解
特性 描述
原子性 (Atomicity) 事务是最小执行单位,操作要么全成功,要么全失败(如转账操作:扣款和到账必须同时成功或失败)。
一致性 (Consistency) 事务完成后数据必须保持一致性状态(如A账户-100,B账户必须+100)。
隔离性 (Isolation) 事务间相互隔离,避免中间状态被其他事务感知(如事务A未提交时,事务B无法看到中间结果)。
持久性 (Durability) 事务提交后数据永久存储到磁盘(即使系统崩溃也不丢失)。
sql 复制代码
-- 示例:银行转账事务
BEGIN;
UPDATE accounts SET balance = balance - 100 WHERE id = 1;
UPDATE accounts SET balance = balance + 100 WHERE id = 2;
COMMIT;

2. 事务操作与保存点

2.1 基本事务操作
  1. 开启事务BEGIN
  2. 提交事务COMMIT
  3. 回滚事务ROLLBACK
sql 复制代码
BEGIN;
INSERT INTO test (id, name) VALUES (7, 'Test');
-- 若操作有误,可回滚
ROLLBACK;
-- 或提交
COMMIT;
2.2 保存点(Savepoint)
  • 作用:将大事务分段,允许部分回滚。

  • 关键命令

    sql 复制代码
    SAVEPOINT savepoint_name;
    ROLLBACK TO savepoint_name;

示例

sql 复制代码
BEGIN;
INSERT INTO orders (product_id, quantity) VALUES (101, 2);
SAVEPOINT after_order;
UPDATE inventory SET stock = stock - 2 WHERE product_id = 101;
-- 若库存更新失败,回滚到保存点
ROLLBACK TO after_order;
COMMIT;

3. 事务隔离级别与并发问题

3.1 并发问题类型
问题 描述
脏读 (Dirty Read) 读取到其他事务未提交的数据(必须避免)。
不可重复读 (Non-Repeatable Read) 同一事务多次查询同一数据结果不一致(如中间有其他事务提交了修改)。
幻读 (Phantom Read) 同一事务多次查询数据集不一致(如其他事务插入新数据)。
3.2 PostgreSQL隔离级别
隔离级别 解决的问题 特点
读已提交 (Read Committed) 脏读 PostgreSQL默认级别,事务只能看到已提交的数据。
可重复读 (Repeatable Read) 脏读、不可重复读 通过快照保证事务内数据一致性(实际效果等同于串行化)。
串行化 (Serializable) 所有问题 最高隔离级别,事务串行执行(性能较低)。

4. MVCC多版本并发控制

4.1 MVCC核心机制
  • 实现原理 :每行数据维护多个版本(通过xminxmax字段记录事务版本号)。
  • 读写分离
    • 读操作访问旧版本数据(避免阻塞写操作)。
    • 写操作生成新版本(不影响正在进行的读操作)。

示例

sql 复制代码
-- 事务A
BEGIN;
SELECT * FROM products WHERE id = 1; -- 读取版本100

-- 事务B
BEGIN;
UPDATE products SET price = 200 WHERE id = 1;
COMMIT; -- 生成版本101

-- 事务A再次查询仍读取版本100
COMMIT;

5. 锁机制

5.1 表锁与行锁对比
锁类型 语法示例 行为
表锁 LOCK TABLE test IN ACCESS EXCLUSIVE MODE; 锁定整张表(阻塞所有读写操作)。
行锁 SELECT * FROM test WHERE id = 1 FOR UPDATE; 锁定单行(其他事务无法修改该行,但可读取)。
5.2 行锁使用场景
sql 复制代码
-- 事务A获取行锁
BEGIN;
SELECT * FROM orders WHERE id = 100 FOR UPDATE;

-- 事务B尝试修改被阻塞
BEGIN;
UPDATE orders SET status = 'shipped' WHERE id = 100; -- 等待事务A提交

6. 实践建议

  1. 避免大事务:使用保存点或最终一致性方案(如消息队列)。
  2. 优先行锁:减少锁竞争,提升并发性能。
  3. 合理选择隔离级别:根据业务需求平衡一致性和性能。
  4. 监控锁冲突 :使用pg_locks视图排查阻塞问题。
sql 复制代码
-- 查看当前锁状态
SELECT * FROM pg_locks;
相关推荐
@LetsTGBot搜索引擎机器人几秒前
2025 Telegram 最新免费社工库机器人(LetsTG可[特殊字符])搭建指南(含 Python 脚本)
数据库·搜索引擎·机器人·开源·全文检索·facebook·twitter
计算机毕设VX:Fegn089526 分钟前
计算机毕业设计|基于springboot + vue动物园管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
冉冰学姐1 小时前
SSM校园排球联赛管理系统y513u(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架应用·开题报告、
Tony Bai1 小时前
【分布式系统】03 复制(上):“权威中心”的秩序 —— 主从架构、一致性与权衡
大数据·数据库·分布式·架构
wb043072012 小时前
SQL工坊不只是一个ORM框架
数据库·sql
至善迎风2 小时前
Redis完全指南:从诞生到实战
数据库·redis·缓存
QQ_4376643144 小时前
Redis协议与异步方式
数据库·redis·bootstrap
纪莫5 小时前
技术面:MySQL篇(InnoDB事务执行过程、事务隔离级别、事务并发异常)
数据库·java面试⑧股
Nerd Nirvana5 小时前
数据库模型全景:从原理到实践的系统性指南
数据库·oracle·电力行业
SelectDB5 小时前
从 Greenplum 到 Doris:集群缩减 2/3、年省数百万,度小满构建超大规模数据分析平台经验
数据库·数据分析·apache