1、定义:
锁(lock)机制用于管理对共享资源的并发访问(使对这些共享资源的并发性访问串行化),同时还能提供数据完整性和一致性。
2、Oracle锁特征:
在Oracle中锁不是稀有资源;
Oracle不会自动升级锁,永远不会;
在Oracle中,行级锁没有相关的开销
3、Oracle锁分类
DML锁
DDL锁
内部锁或LATCH
4、锁一览图锁代码锁模式名称锁模式简写锁模式级别备注说明隐式产生锁显式产生锁
0NoneNone无锁模式,select操作便是这样的情况
1NullNull表级锁Oracle在内存中自动加的锁,主要起通知作用
2Row-SSS表级锁10g版本前:FOR UPDATELOCKTABLE表名INROWSHAREMODE;
3Row-SXSX表级锁行级排它锁,主要由DML语句引起10g版本后:FOR UPDATE、DML语句LOCKTABLE表名INROWEXCLUSIVEMODE;
4ShareS表级锁共享锁、只读锁LOCKTABLE表名INSHAREMODE;
5S/Row-XSSX表级锁共享行排它锁LOCKTABLE表名INSHAREROWEXCLUSIVEMODE;
6ExclusiveX表级锁/行级锁排它锁
R:Row S:Share X:Exclusive
5、TM锁兼容性NSSSXSSSXX
NYESYESYESYESYESYES
SSYESYESYESYESYESNO
SXYESYESYESNONONO
SYESYESNOYESNONO
SSXYESYESNONONONO
XYESNONONONONO
6、锁常用sql
--测试子表:成绩表
SELECT*FROMscore;
--测试父表:学生信息表
SELECT*FROMstudent;
--查询当前会话值
SELECT*FROMv$mystatWHEREROWNUM='1';
--动态性能视图 v$locked_object 各字段的含义
SELECTl.XIDUSNAS回滚段号,
l.XIDSLOTAS回滚槽号,
l.XIDSQNAS回滚序列号,
l.OBJECT_IDAS被锁对象ID,
l.SESSION_IDAS持有锁对象会话ID,
l.ORACLE_USERNAMEAS持有锁的oracle用户名,
l.OS_USER_NAMEAS持有锁操作系统用户名,
l.PROCESSAS操作系统进程号,
l.LOCKED_MODEAS锁模式
FROMv$locked_object l;
--当前用户创建的所有对象,列出部分常用字段含义
SELECTuo.object_nameAS对象名称,
uo.object_idAS对象ID,
uo.object_typeAS对象类型
FROMuser_objects uo;
--通过v$locked_object与user_objects两表关联可以得出被锁的是哪个表以及是被哪个用户锁的
SELECTuo.object_nameAS对象名称,
uo.object_typeAS对象类型,
l.ORACLE_USERNAMEAS持有锁的oracle用户名,
l.LOCKED_MODEAS锁模式
FROMv$locked_object l,user_objects uo
WHEREl.OBJECT_ID =uo.object_id;
/* AND l.SESSION_ID=&session_id;*/
--查询所有正在等待获得锁的会话ID及锁类型
SELECTw.waiting_sessionAS等待锁的会话ID,
w.holding_sessionAS持有锁的会话ID,
w.lock_typeAS锁类型,
w.mode_heldAS锁机制
FROMdba_waiters w;
--动态性能视图事务执行列表(未提交状态),BLOCK=1是堵塞者,BLOCK=0是被堵塞者
SELECT*FROMv$transaction_enqueue;
--查询阻挡关系
SELECT(SELECTs.USERNAMEFROMv$session sWHEREs.SID = a.SID)AS阻挡者名,
a.SIDAS阻挡者会话ID,
'正在阻挡'AS行为,
(SELECTs.USERNAMEFROMv$session sWHEREs.SID = b.SID)AS被阻挡者名,
b.SIDAS被阻挡者会话ID
FROMv$lock a, v$lock b
WHEREa.ID1 = b.ID1
ANDa.ID2 = b.ID2
ANDa.BLOCK=1
ANDb.REQUEST >0;
--根据会话ID查询前一步sql操作语句,这个语句不适合应用程序
SELECTsq.sql_text
FROMv$sql sq
WHEREsq.SQL_ID =
(SELECTs.SQL_IDFROMv$session sWHEREs.SID =&session_id);