行共享锁(Row Share ,RS)

对数据表定义了行共享锁后,如果被事务A获得,那么其他事务可以进行并发查询、插入、删除及加锁,但不能以排他方式存取该数据表。

为Student表添加行共享锁

mysql排他锁和共享锁区别 oracle共享锁和排他锁_mysql排他锁和共享锁区别

行排他锁(Row Exclusive,RX)

当事务A获得行排他锁后,其他事务可以对同一数据表中的其他数据行进行并发查询、插入、修改、删除及加锁,但不能使用行共享锁、行共享排他锁和行排他锁3种方式加锁。

为Student表添加行排他锁

mysql排他锁和共享锁区别 oracle共享锁和排他锁_共享锁_02

共享锁(Share,S)

当事务A获得共享锁后,其他事务可以对同一数据表中的其他数据行进行并发查询、加共享锁但不能修改表,不能使用排他锁、行共享排他锁和行排他锁3种方式加锁。

为Student表添加共享锁

第一步:为表Student添加排他锁

mysql排他锁和共享锁区别 oracle共享锁和排他锁_共享锁_03

第二步:打开一个新的SQL Plus会话,分别执行查询和更新操作

mysql排他锁和共享锁区别 oracle共享锁和排他锁_共享锁_04

此时,新打开的会话可以查询,但是更新语句一直处于锁等待的状态。回到第一个会话,当解除锁,例如输入rollback回滚操作后,新会话会立刻执行完成。

mysql排他锁和共享锁区别 oracle共享锁和排他锁_Oracle_05

共享行排他锁(Share Row Exclusive,SRX)

当事务A获得共享排他锁后,其他事务可以执行查询和对其他数据行加锁,但不能修改表,也不能再添加共享锁、共享行排他锁、行排他锁和排他锁。

为Student添加共享行排他锁

第一步:为Student添加共享行排他锁

mysql排他锁和共享锁区别 oracle共享锁和排他锁_共享锁_06

第二步:新会话中为student添加共享锁

mysql排他锁和共享锁区别 oracle共享锁和排他锁_加锁的方法_07


发现,新打开的会话窗口,为已经添加共享排他锁的事务再次添加共享锁时,一直处于等待状态,当第一个会话释放资源时,第二个会话方可执行。

mysql排他锁和共享锁区别 oracle共享锁和排他锁_mysql排他锁和共享锁区别_08

排他锁(Exclusive,X)

排他锁是最严格的锁,当事务A获得排他锁后,事务A可以执行对数据表的读写操作,其他事务可以执行查询但不能执行插入、修改和删除操作。

其他事务可以执行查询和对其他数据行加锁,但不能修改表,也不能再添加共享锁、共享行排他锁,行排他锁和排他锁。

为Student表添加排他锁

第一步:为表Student添加排他锁

mysql排他锁和共享锁区别 oracle共享锁和排他锁_mysql排他锁和共享锁区别_09

第二步:打开一个新的SQL Plus会话,分别执行查询和更新操作

mysql排他锁和共享锁区别 oracle共享锁和排他锁_mysql排他锁和共享锁区别_10


此时,新打开的会话可以查询,但是更新语句一直处于锁等待状态。回到第一个会话,解除锁,新会话立刻执行完成。

mysql排他锁和共享锁区别 oracle共享锁和排他锁_Oracle_11