下午操作数据库,可能由于数据量比较大,造成锁表,本以为可以轻松kill掉,没想到出现ora-00030错误,在网上找了解决方法,但是都没有成功kill掉锁表,特来求教,望高手指教!
下面是我用过的方法:
查看锁表进程SQL语句1:
select sess.sid,
sess.serial#,
lo.oracle_username,
lo.os_user_name,
ao.object_name,
lo.locked_mode
from v$locked_object lo,
dba_objects ao,
v$session sess
where ao.object_id = lo.object_id and lo.session_id = sess.sid;
杀掉锁表进程:
如有记录则表示有lock,记录下SID和serial# ,将记录的ID替换下面的xx,xxx,即可解除LOCK
alter system kill session 'xx,xxx'; 然后,网上有说,使用下面的SQL语句,但是我使用后,没有效果.
alter session set events 'immediate trace name flush_cache level 1'; oracle锁表ora-00030session
下面是我用过的方法:
查看锁表进程SQL语句1:
select sess.sid,
sess.serial#,
lo.oracle_username,
lo.os_user_name,
ao.object_name,
lo.locked_mode
from v$locked_object lo,
dba_objects ao,
v$session sess
where ao.object_id = lo.object_id and lo.session_id = sess.sid;
杀掉锁表进程:
如有记录则表示有lock,记录下SID和serial# ,将记录的ID替换下面的xx,xxx,即可解除LOCK
alter system kill session 'xx,xxx'; 然后,网上有说,使用下面的SQL语句,但是我使用后,没有效果.
alter session set events 'immediate trace name flush_cache level 1'; oracle锁表ora-00030session
如果是这样,表示已经成功killed了,pmon会自动帮你清理
killed成功了,它会多久释放会话?
我看网上有人也遇到这种情况,说两天也没有释放掉,最后通过杀掉进程成功了,但是我通过杀掉进程的命令也没有成功。可能是因为我是远程的机器吧,网上说用telnet命令,但是这个我不熟悉,还没有用过……