1. 先查询出来有哪些锁select object_name,machine,s.sid,s.serial#
from v$locked_object l,dba_objects o ,v$session s
where l.object_id = o.object_id and l.session_id=s.sid;
2. 可以查一下执行的SQL和进程IDselect s.program, p.spid, a.sql_text,a.SQL_ID
from v$session s, v$process p, v$sqlarea a
where s.paddr = p.addr
and s.sql_hash_value = a.hash_value
and s.username is not null
and s.sid=&sid;
3.如果确认要kill会话,用下边的SQL其中一个,其中sid和serial#是第一步里的查询结果alter system kill session 'sid, serial#';
alter system disconnect session 'sid, serial#' immediate;
比如alter system kill session '512,62747';
4. 有时候即使执行了上边的SQL,会话仍然存在, 这时候需要执行操作系统层级的命令orakill,杀掉执行这个SQL的线程。orakill在oracle的安装目录中,一般是$\product\11.2.0\dbhome_1\bin, 命令有两个参数 sid、thread,其中sid是你的oracle的实例名,一般是oral,可以在服务里看有没有OracleServiceXXX这样的服务, 这里的XXX就是实例名。orakill oral 3432