oracle强制关闭session,Oracle终止session

有时候,oracle终止当前的session是必要的。例如,你想执行一个管理操作,需要终止所有非管理员的session。下面描述的是终止sess

有时候,Oracle终止当前的session是必要的。例如,你想执行一个管理操作,需要终止所有非管理员的session。下面描述的是终止session的各个方面,包括以下:

1.标识哪些session需要终止

2.终止一个Active Session

3.终止一个Inactive Session

当一个session被终止,session的任何活动事务回滚,并且立即释放所有的资源,比如locks and memoryareas。

使用ALTERSYSTEM KILL SESSION终止一个会话。下面的例句sid 7,serial# 15:

ALTER SYSTEMKILL SESSION '7,15';

1. 标识哪些session需要终止

为了标识需要终止的session,需要知道session的sid和serial#,可以查询v$session得到。例如,下面的查询标识了用户wxlun的所有session:

SQL> SELECT SID, SERIAL#, STATUS FROM V$SESSION WHERE USERNAME ='WXLUN';

SID SERIAL#STATUS

---------- ---------- --------

81 19713 ACTIVE

95 27537 INACTIVE

当一个session正在调用数据库,session状态为ACTIVE,当一个session非正在调用数据库,session状态为INACTIVE。

2. 终止一个Active Session

如果一个用户session正在处理事务(ACTIVE),终止这个会话,则事务回滚,用户立即收到下面的信息:

ORA-00028: your session has been killed

如果,接到ORA-00028错误后,再重新连接数据库前继续执行语句,,oracle会返还下面的信息:

ORA-01012: not loggedon(使用不同的工具连接到数据库可能收到的信息不同,但是类似,都是指和库的session断了)

当一个session正在执行网络I/O或者事务回滚时,是不能终止的。这类session只能等操作完成才可以终止。这种情况下,直到session终止,资源才会释放。另外,发出ALTERSYSTEM去终止session的会话,等待60秒后没有终止session,会收到一个信息表明session已标识为终止。被标记为终止的session在v$seession的status为KILLED,某些终止服务status可能为PSEUDO。

3. 终止一个Inactive Session

如果终止一个InactiveSession,并不会立即收到ORA-00028错误。直到用户接着使用被终止的session才会收到ORA-00028错误。

当一个inactivesession,session的status变成KILLED,当用户再次使用这个session和收到ORA-00028错误,这个终止的session会从v$session删除。

下面是一个终止inactive session的例子。

SQL> SELECT SID, SERIAL#, STATUS FROM V$SESSION WHERE USERNAME ='WXLUN';

SID SERIAL#STATUS

---------- ---------- --------

95 27591 INACTIVE

SQL> alter system kill session '95,27591';

System altered.

SQL> SELECT SID, SERIAL#, STATUS FROM V$SESSION WHERE USERNAME ='WXLUN';

SID SERIAL#STATUS

---------- ---------- --------

95 27591 KILLED

SQL>

相关阅读:

Oracle 10 DBMS_MONITOR跟踪和分析其它session SQL

快速找到跟踪其他session产生的trc文件

Oracle 彻底 kill session

MySQL主从故障处理--session 级别参数复制错误

如何查看Oracle数据库的session阻塞

logo.gif

1428d0e076c3959ab11d28a39bc84fab.png

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:php中文网

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值