Oracle锁
1、定义:
站在用户的角度思考问题,与客户深入沟通,找到阿克陶网站设计与阿克陶网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:成都做网站、成都网站建设、成都外贸网站建设、企业官网、英文网站、手机端网站、网站推广、域名与空间、虚拟空间、企业邮箱。业务覆盖阿克陶地区。
锁(lock)机制用于管理对共享资源的并发访问(使对这些共享资源的并发性访问串行化),同时还能提供数据完整性和一致性。
2、Oracle锁特征:
在Oracle中锁不是稀有资源;
Oracle不会自动升级锁,永远不会;
在 Oracle 中,行级锁没有相关的开销
3、Oracle锁分类
DML锁
DDL锁
内部锁或LATCH
4、锁一览图
锁代码 | 锁模式名称 | 锁模式简写 | 锁模式级别 | 备注说明 | 隐式产生锁 | 显式产生锁 |
0 | None | None | 无锁模式,select操作便是这样的情况 | |||
1 | Null | Null | 表级锁 | Oracle在内存中自动加的锁,主要起通知作用 | ||
2 | Row-S | SS | 表级锁 | 10g版本前:FOR UPDATE | LOCK TABLE 表名IN ROW SHARE MODE; | |
3 | Row-SX | SX | 表级锁 | 行级排它锁,主要由DML语句引起 | 10g版本后:FOR UPDATE、DML语句 | LOCK TABLE 表名IN ROW EXCLUSIVE MODE; |
4 | Share | S | 表级锁 | 共享锁、只读锁 | LOCK TABLE 表名IN SHARE MODE; | |
5 | S/Row-X | SSX | 表级锁 | 共享行排它锁 | LOCK TABLE 表名 IN SHARE ROW EXCLUSIVE MODE; | |
6 | Exclusive | X | 表级锁/行级锁 | 排它锁 | ||
R:Row S:Share X:Exclusive |
5、TM锁兼容性
N | SS | SX | S | SSX | X | |
N | YES | YES | YES | YES | YES | YES |
SS | YES | YES | YES | YES | YES | NO |
SX | YES | YES | YES | NO | NO | NO |
S | YES | YES | NO | YES | NO | NO |
SSX | YES | YES | NO | NO | NO | NO |
X | YES | NO | NO | NO | NO | NO |
6、锁常用sql
--测试子表:成绩表
SELECT *FROM score;
--测试父表:学生信息表
SELECT *FROM student;
--查询当前会话值
SELECT *FROM v$mystatWHEREROWNUM='1';
--动态性能视图 v$locked_object 各字段的含义
SELECT l.XIDUSN AS回滚段号,
l.XIDSLOT AS回滚槽号,
l.XIDSQN AS回滚序列号,
l.OBJECT_ID AS被锁对象ID,
l.SESSION_ID AS持有锁对象会话ID,
l.ORACLE_USERNAMEAS持有锁的oracle用户名,
l.OS_USER_NAME AS持有锁操作系统用户名,
l.PROCESS AS操作系统进程号,
l.LOCKED_MODE AS锁模式
FROM v$locked_object l;
--当前用户创建的所有对象,列出部分常用字段含义
SELECT uo.object_nameAS对象名称,
uo.object_id AS对象ID,
uo.object_typeAS对象类型
FROM user_objects uo;
--通过v$locked_object与user_objects两表关联可以得出被锁的是哪个表以及是被哪个用户锁的
SELECT uo.object_name AS对象名称,
uo.object_type AS对象类型,
l.ORACLE_USERNAMEAS持有锁的oracle用户名,
l.LOCKED_MODE AS锁模式
FROM v$locked_object l,user_objects uo
WHERE l.OBJECT_ID =uo.object_id;
/* AND l.SESSION_ID=&session_id;*/
--查询所有正在等待获得锁的会话ID及锁类型
SELECT w.waiting_sessionAS等待锁的会话ID,
w.holding_sessionAS持有锁的会话ID,
w.lock_type AS锁类型,
w.mode_held AS锁机制
FROM dba_waiters w;
--动态性能视图事务执行列表(未提交状态),BLOCK=1是堵塞者,BLOCK=0是被堵塞者
SELECT *FROM v$transaction_enqueue;
--查询阻挡关系
SELECT (SELECT s.USERNAMEFROM v$session sWHERE s.SID = a.SID)AS阻挡者名,
a.SIDAS阻挡者会话ID,
'正在阻挡'AS行为,
(SELECT s.USERNAMEFROM v$session sWHERE s.SID = b.SID)AS被阻挡者名,
b.SIDAS被阻挡者会话ID
FROM v$lock a, v$lock b
WHERE a.ID1 = b.ID1
AND a.ID2 = b.ID2
AND a.BLOCK =1
AND b.REQUEST >0;
--根据会话ID查询前一步sql操作语句,这个语句不适合应用程序
SELECT sq.sql_text
FROM v$sql sq
WHERE sq.SQL_ID =
(SELECT s.SQL_IDFROM v$session sWHERE s.SID =&session_id);
分享标题:Oracle锁
网页链接:http://pcwzsj.com/article/jpigjc.html