第4步中乙事务修改A并写回后覆盖了甲事务的修改。
并发操作带来的数据不一致性包括三类:
丢失修改;
不一致分析(不可重复读);
读“脏”数据。
并发操作带来的数据不一致性包括三类:
丢失修改; 不一致分析(不可重复读); 读“脏”数据。
1. 丢失更新(Lost update)
指事务Ti与事务Tj从数据库中读入同一数据并修改,事务2的提 交结果破坏了事务1提交的结果,导致事务1的修改被丢失。 时间
时间 t0 t1 t2 t3 t4 检索A、B:A=50,B=100
事务Ti
数据库中A、B的值 50、100
事务Tj
求和: A+B=150
检索B:B=100 修改B:B←B*2
t5
t6 t7 t8 检索(验算):A=50,B=200
写回B:B=200
50、200
求和:A)包括三种情况:
二、并发调度的可串行化
1、概念 事务的调度: 串行调度: 事务的执行次序称为“调度”。 如果多个事务依次执行,则称为事务的串行 调度(Serial Schedule)。 并发调度: 如果利用分时的方法,同时处理多个事 务,则称为事务的并发调度(Concurrent Schedule)。 在事务并发执行时,有可能破坏数据库的一致性,
或用户读了脏数据。
如果有n个事务串行调度,可有n!种不同的有效调度。 如果有n个事务并发调度,可能的并发调度数目远远大于n!。
DBMS的并发控制子系统实现: 如何产生正确的并发调度。 如何判断一个并发调度是正确的,
用并发调度的可串行化概念解决.
现在有两个事务,分别包含下列操作:
事务T1:读B;A=B十1;写回A;
事务T2:读A;B=A十1;写回B