行共享锁(Row Share ,RS)
对数据表定义了行共享锁后,如果被事务A获得,那么其他事务可以进行并发查询、插入、删除及加锁,但不能以排他方式存取该数据表。
为Student表添加行共享锁
行排他锁(Row Exclusive,RX)
当事务A获得行排他锁后,其他事务可以对同一数据表中的其他数据行进行并发查询、插入、修改、删除及加锁,但不能使用行共享锁、行共享排他锁和行排他锁3种方式加锁。
为Student表添加行排他锁
共享锁(Share,S)
当事务A获得共享锁后,其他事务可以对同一数据表中的其他数据行进行并发查询、加共享锁但不能修改表,不能使用排他锁、行共享排他锁和行排他锁3种方式加锁。
为Student表添加共享锁
第一步:为表Student添加排他锁
第二步:打开一个新的SQL Plus会话,分别执行查询和更新操作
此时,新打开的会话可以查询,但是更新语句一直处于锁等待的状态。回到第一个会话,当解除锁,例如输入rollback回滚操作后,新会话会立刻执行完成。
共享行排他锁(Share Row Exclusive,SRX)
当事务A获得共享排他锁后,其他事务可以执行查询和对其他数据行加锁,但不能修改表,也不能再添加共享锁、共享行排他锁、行排他锁和排他锁。
为Student添加共享行排他锁
第一步:为Student添加共享行排他锁
第二步:新会话中为student添加共享锁
发现,新打开的会话窗口,为已经添加共享排他锁的事务再次添加共享锁时,一直处于等待状态,当第一个会话释放资源时,第二个会话方可执行。
排他锁(Exclusive,X)
排他锁是最严格的锁,当事务A获得排他锁后,事务A可以执行对数据表的读写操作,其他事务可以执行查询但不能执行插入、修改和删除操作。
其他事务可以执行查询和对其他数据行加锁,但不能修改表,也不能再添加共享锁、共享行排他锁,行排他锁和排他锁。
为Student表添加排他锁
第一步:为表Student添加排他锁
第二步:打开一个新的SQL Plus会话,分别执行查询和更新操作
此时,新打开的会话可以查询,但是更新语句一直处于锁等待状态。回到第一个会话,解除锁,新会话立刻执行完成。