关于Kill Oracle 锁会话相关的总结

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和进程ID

select 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

你可能感兴趣的:(关于Kill Oracle 锁会话相关的总结)