问题提出:对一个100万条数据的表错误的进行了UPDATE操作,而后终止了此操作,后来用户反映应用相应慢,开发人员以为是该表的索引出现问题,在删除索引时报错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 order by t2.logon_time;
如:testuser 339 13545 2010-7-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';
至此问题解决。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10537377/viewspace-667300/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/10537377/viewspace-667300/