1. 当用户正在处理一个事务时(ACTIVE),此时被kill时会进行rolled back,用户客户端会报错:
ORA-00028: your session has been killed
此时进行commit时会报:
ORA-03114: not connected to ORACLE
2. active session:
ACTIVE session在执行network I/O或rolling back事务时不能被中断,直到操作完成才会释放所有资源!
期间该session会被标记为killed或者pseudo状态。
3. inactive session:
INACTIVE session被kill时,先被标记killed,然后改行记录送v$session中移除。
4. 对于ACTIVE session,可以使用 immediate选项,强制立即Kill会话,如下:
SQL> alter system kill session '
sid, serial#' immediate;
注:immediate会立即断开session,而不用等待事务完成。
--批量kill
select 'alter system kill session'''||sid||','||SERIAL#||''' immediate;' from v$session where username in ('USER1','USER2');
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/27126919/viewspace-1959108/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/27126919/viewspace-1959108/