背景
为验证程序能否在锁表的情况还能正常处理业务逻辑,所以需要手工锁表,创造测试条件。
方法
手工锁表:
lock table TABLE_NAME in row share mode nowait; --2
lock table TABLE_NAME in share update mode nowait; --2
lock table TABLE_NAME in row exclusive mode nowait; --3
lock table TABLE_NAME in share mode nowait; --4
lock table TABLE_NAME in share row exclusive mode nowait; --5
lock table TABLE_NAME in exclusive mode nowait; --6
0:none
1:null 空
2:Row-S 行共享(RS):共享表锁
3:Row-X 行专用(RX):用于行的修改
4:Share 共享锁(S):阻止其他DML操作
5:S/Row-X 共享行专用(SRX):阻止其他事务操作
6:exclusive 专用(X):独立访问使用
手工解锁:
rollback/commit
需要注意,在新的会话中才能验证到锁表的现象。