Oracleoracle锁表处理

 

死锁的规律:当对于数据库某个表的某一列做革新或删除等操作,执行完毕后该条语句不提交,另一条对于这一列数据做革新操作的话语在实施的时候就会处在等候状态,此时的情形是这条语句一贯在举行,但一贯未曾履行成功,也绝非报错。

Oracle里锁有以下两种格局: 

*  0:none 
  1:null 空 
  2:Row-S 行共享(RS):共享表锁 
  3:Row-X 行专用(RX):用于行的修改 
  4:Share 共享锁(S):阻止其他DML操作 
  5:S/Row-X 共享行专用(SRX):阻止其他作业操作 
  6:exclusive 专用(X):独立访问使用 
   
数字越大锁级别越高, 影响的操作越多。 
诚如的询问语句如select … from … ;是低于2的锁,
有时会在v$locked_object出现。 
   
  select … from … for update; 是2的锁。 
   
当对话使用for update子串打开一个游标时, 
怀有重回集中的数额行都将远在行级(Row-X)独占式锁定, 
此外对象只可以查询这么些多少行,不可以开展update、delete或select…for
update操作。 
   
  insert / update / delete … ; 是3的锁。 
   
  没有commit从前插入同样的一条记录会没有反应, 
  因为后一个3的锁会平素等候上一个3的锁,
大家必须自由掉上一个才能继承做事。 
   
  制造索引的时候也会暴发3,4级另外锁。 
   
  locked_mode为2,3,4不影响DML(insert,delete,update,select)操作, 
  但DDL(alter,drop等)操作会指示ora-00054不当。 
   
  有主外键约束时 update / delete … ; 可能会暴发4,5的锁。 
   
  DDL语句时是6的锁。 
   
  以DBA角色, 查看当前数据库里锁的意况可以用如下SQL语句:*

  select object_id,session_id,locked_mode from v$locked_object;

  select t2.username,t2.sid,t2.serial#,t2.logon_time 
  from v$locked_object t1,v$session t2 
  where t1.session_id=t2.sid order by t2.logon_time;

  假若有一劳永逸出现的一列,可能是一贯不自由的锁。 
   
  我们可以用上面SQL语句杀掉短期并未自由非正常的锁:

  alter system kill session ‘sid,serial#’;

  假如出现了锁的题材, 某个DML操作可能等待很久没有影响。 
   
  当您使用的是直接连接数据库的法门, 
  也决不用OS系统命令 $kill process_num 或者 $kill -9
process_num来终止用户连接, 
  因为一个用户进程可能爆发一个之上的锁,
杀OS进程并不可能彻底清除锁的问题。 
   
  记得在数据库级别用alter system kill session
‘sid,serial#’;杀掉不正常的锁。

当工作得到行锁后,此工作也将机关获取该行的表锁(共享锁),以防范其他业务举办DDL语句影响记录行的换代。事务也可以在进行过程中取得共享锁或排它锁,唯有当事情显示应用LOCK
TABLE语句展现的定义一个排它锁时,事务才会拿走表上的排它锁,也可采纳LOCK
TABLE呈现的概念一个表级的共享锁
,所以行锁的时候自己还的拿个表锁,免得其旁人该了自家的表结构如故去除了自家的表。

 

锁表查询SQL
SELECT object_name, machine, s.sid, s.serial#
FROM gv$locked_object l, dba_objects o, gv$session s
WHERE l.object_id = o.object_id
AND l.session_id = s.sid;

–释放SESSION SQL:
–alter system kill session ‘sid, serial#’;
如:  ALTER system kill session ’23, 1647′;

 

–查出oracle当前的被锁对象
SELECT l.session_id sid, s.serial#, l.locked_mode 锁模式,
l.oracle_username 登录用户,
l.os_user_name 登录机器用户名, s.machine 机器名, s.terminal
终端用户名, o.object_name 被锁对象名,s.logon_time 登录数据库时间
FROM v$locked_object l, all_objects o, v$session s
WHERE l.object_id = o.object_id AND l.session_id = s.sid
ORDER BY sid, s.serial#;

 

–查询什么SQL引起的锁表
select l.session_id sid,
s.serial#,
l.locked_mode,
l.oracle_username,
s.user#,
l.os_user_name,
s.machine,
s.terminal,
a.sql_text,
a.action
from v$sqlarea a, v$session s, v$locked_object l
where l.session_id = s.sid
and s.prev_sql_addr = a.address
order by sid, s.serial#;

–kill掉当前的锁对象可以为
alter system kill session ‘sid, s.serial#‘;

 

–查询死锁,并可以观看死锁的机械是那一台

select username,lockwait,status,machine,program from v$session where sid
in
(select session_id from v$locked_object)

 

假如还无法迎刃而解:

select pro.spid from v$session ses,v$process pro where ses.sid=XX and
ses.paddr=pro.addr;

里面sid用死锁的sid替换: exit

ps -ef|grep spid

个中spid是其一进程的历程号,kill掉这么些Oracle进程

 

相关文章