1)找出当前会话ID的方法select sid from v$mystat where rownum=1
2)找出阻塞的会话IDselect * from dba_blockers
3)得到会话的详细信息SELECT a.username, a.program, a.SID, a.serial#
FROM v$session a, dba_blockers b
WHERE a.SID = b.holding_session
4)杀掉会话alter system kill session 'sid,serial#'输入3)得到的sid,serial#就可以了。
5)这个杀掉的是阻塞别人的第一个会话。比如第一个session运行一个sql,没有提交的时候,第二个执行了一个sql,被第一个阻塞,这种情况下,dba_blockers记录的是第一个会话ID.
6)如果还有第三个会话也被阻塞,3)的运行结果,就会出现3行,出现3个会话信息,杀掉第一个会话就可以了
7)还有一个办法SELECT username, sid,blocking_session, blocking_session_status
FROM v$session
WHERE blocking_session_status = 'VALID'这里,sid是被阻塞的会话,blocking_session是阻塞的会话,杀掉blocking_sesion对应的会话就可以了。找到被阻塞的会话ID,杀掉就可以了。
关键词标签:Oracle
相关阅读
热门文章
Oracle中使用alter table来增加,删除,修改列的语法
oracle中使用SQL语句修改字段类型-oracle修改SQL语句案例
误删Oracle数据库实例的控制文件
为UNIX服务器设置Oracle全文检索
人气排行 oracle中使用SQL语句修改字段类型-oracle修改SQL语句案例 Oracle中使用alter table来增加,删除,修改列的语法 ORACLE SQL 判断字符串是否为数字的语句 ORACLE和SQL语法区别归纳(1) oracle grant 授权语句 ORACLE修改IP地址后如何能够使用 如何加速Oracle大批量数据处理 Oracle删除表的几种方法
查看所有0条评论>>