在 Oracle 中,当你开启一个事务(例如,通过执行 BEGIN
语句或直接执行 DML 语句如 INSERT
、 UPDATE
或 DELETE
)时,以下行为会发生:
-
**行级锁**:当你修改数据时(例如,执行
INSERT
、UPDATE
或DELETE
),Oracle 会在受影响的行上加上行级锁。其他尝试修改相同行的事务将被阻塞,直到第一个事务提交或回滚。 -
**读一致性**:其他事务仍然可以读取正在被修改的数据,但他们会看到数据在事务开始之前的状态。这是由于 Oracle 的多版本并发控制(MVCC)机制,提供了读一致性。因此,在一个事务进行时,其他查询可以读取数据而不会被阻塞。
-
**阻塞行为**:如果另一个事务尝试修改与第一个事务锁定的相同行,它将被阻塞,直到第一个事务完成。如果它尝试读取被锁定的行,它将看到事务开始之前的旧版本的数据,而不会被阻塞。
示例场景
-
**事务 A** 开始并更新一个表中的行。
-
**事务 B** 尝试更新相同的行。事务 B 将被阻塞,直到事务 A 提交或回滚。
-
**事务 C** 尝试在事务 A 仍然开放时读取相同的行。事务 C 将看到该行的旧版本(在事务 A 更新之前),并且不会被阻塞。
总之,在 Oracle 中,当一个事务处于活动状态时: - 其他事务可以读取数据,而不会被阻塞。 - 其他事务尝试修改相同数据时将被阻塞,直到第一个事务完成