本文共 925 字,大约阅读时间需要 3 分钟。
对数据表定义了行共享锁后,如果被事务A获得,那么其他事务可以进行并发查询、插入、删除及加锁,但不能以排他方式存取该数据表。
为Student表添加行共享锁
当事务A获得行排他锁后,其他事务可以对同一数据表中的其他数据行进行并发查询、插入、修改、删除及加锁,但不能使用行共享锁、行共享排他锁和行排他锁3种方式加锁。
为Student表添加行排他锁
当事务A获得共享锁后,其他事务可以对同一数据表中的其他数据行进行并发查询、加共享锁但不能修改表,不能使用排他锁、行共享排他锁和行排他锁3种方式加锁。
为Student表添加共享锁
第一步:为表Student添加排他锁
第二步:打开一个新的SQL Plus会话,分别执行查询和更新操作
此时,新打开的会话可以查询,但是更新语句一直处于锁等待的状态。回到第一个会话,当解除锁,例如输入rollback回滚操作后,新会话会立刻执行完成。
当事务A获得共享排他锁后,其他事务可以执行查询和对其他数据行加锁,但不能修改表,也不能再添加共享锁、共享行排他锁、行排他锁和排他锁。
为Student添加共享行排他锁
第一步:为Student添加共享行排他锁
第二步:新会话中为student添加共享锁
排他锁是最严格的锁,当事务A获得排他锁后,事务A可以执行对数据表的读写操作,其他事务可以执行查询但不能执行插入、修改和删除操作。
其他事务可以执行查询和对其他数据行加锁,但不能修改表,也不能再添加共享锁、共享行排他锁,行排他锁和排他锁。
为Student表添加排他锁
第一步:为表Student添加排他锁
第二步:打开一个新的SQL Plus会话,分别执行查询和更新操作
转载地址:http://ekpqb.baihongyu.com/