下午操作数据库,可能由于数据量比较大,造成锁表,本以为可以轻松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

解决方案 »

  1.   

    你在alter system kill session x,y;的时候一直报ora-00030的错误吗?
    如果是这样,表示已经成功killed了,pmon会自动帮你清理
      

  2.   

    plsql developer 里面有一个会话,去检查一下,如果感觉不爽,直接右键点击 kill掉
      

  3.   

    是的,alter system kill session x,y;的时候一直报ora-00030的错误
    killed成功了,它会多久释放会话?
    我看网上有人也遇到这种情况,说两天也没有释放掉,最后通过杀掉进程成功了,但是我通过杀掉进程的命令也没有成功。可能是因为我是远程的机器吧,网上说用telnet命令,但是这个我不熟悉,还没有用过……