oracle锁点滴

用户反映应用页面显示很慢,这是另外一组人负责的,他们并不知道对数据库做了什么操作,以前也出现过类似问题,因为此应用的首页要对此表进行查询,怀疑索引失效,希望重建索引,在重建索引的时候报错ora-00054:resource busy and acquire with nowait specified。通过以下方式找到了问题的根源:
1、用dba权限的用户查看数据库都有哪些锁
select t2.username,t2.sid,t2.serial#,t2.logon_time
from v$locked_object t1,v$session t2
where t1.session_id=t2.sid ;
如:testuser 339 13545 2009-3-5 17:40:05
知道被锁的用户testuser,sid为339,serial#为13545
2、根据sid查看具体的sql语句
select sql_text from v$session a,v$sqltext_with_newlines b
where DECODE(a.sql_hash_value, 0, prev_hash_value, sql_hash_value)=b.hash_value
and a.sid=&sid order by piece;
查出来的sql,一看原来是那条update语句;
3、kill该事务
alter system kill session '339,13545';
至此问题解决。
来源:http://www.chinaoug.net/space.php?uid=356676&do=blog&id=1820

你可能感兴趣的:(oracle,sql,数据库,session,object,kill)