淮安市网站建设_网站建设公司_会员系统_seo优化
2026/1/2 21:02:44
网站建设
项目流程
在并发操作数据库时,如果事务隔离级别没设好,就会出现各种异常现象——你明明刚读到的数据,转眼就变了;或者莫名其妙地发现数据对不上。这就是事务隔离要解决的核心问题:在多个事务同时运行时,如何平衡性能和数据的一致性/正确性。
PostgreSQL 提供了强大的事务隔离级别,让我们能根据业务需求,选择最合适的“防护等级”。
1. 事务并发会遇到的三类异常 1.1 脏读 现象 :事务 A 读到了事务 B 尚未提交 的修改。后来事务 B 回滚了,那么事务 A 读到的就是根本不存在的数据。例子 :A 看到账户有 150 元(B 刚加了 100 元但未提交),A 据此消费。结果 B 的事务回滚,那 100 元消失了,A 的消费就透支了。1.2 不可重复读 现象 :在同一个事务 A 中,两次读取同一条 数据,得到了不同的结果。因为在这两次读取之间,另一个事务 B 修改并提交了这条数据。例子 :事务 A 开始后,第一次查询余额为 100 元。此时事务 B 扣款 50 元并提交。事务 A 再次查询余额,发现变成了 50 元。1.3 幻读 现象 :在同一个事务 A 中,两次执行相同的查询 ,返回的记录行数 不一样。因为另一个事务 B 插入或删除了符合查询条件的记录并提交了。例子 :事务 A 统计“年龄小于 30 的员工人数”,第一次得到 10 人。此时事务 B 插入了一名 25 岁的新员工并提交。事务 A 再次统计,得到了 11 人。不可重复读 vs 幻读 :
不可重复读:针对 同一行 数据(Update)。 幻读:针对 一组条件 结果集(Insert/Delete)。 2. PostgreSQL 的四种事务隔离级别 SQL 标准定义了四个隔离级别,隔离强度从低到高,能预防的异常也越多。PostgreSQ