Welcome 微信登录

首页 / 数据库 / MySQL / Oracle终止session

有时候,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 INACTIVESQL> alter system kill session "95,27591";System altered.SQL> SELECT SID, SERIAL#, STATUS FROM V$SESSION WHERE USERNAME ="WXLUN";      SID    SERIAL#STATUS
---------- ---------- --------
     95   27591 KILLEDSQL>更多Oracle相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12相关阅读:Oracle 10 DBMS_MONITOR跟踪和分析其它session SQL http://www.linuxidc.com/Linux/2013-08/88774.htm快速找到跟踪其他session产生的trc文件 http://www.linuxidc.com/Linux/2013-08/88582.htmOracle 彻底 kill session http://www.linuxidc.com/Linux/2013-06/86339.htmMySQL主从故障处理--session 级别参数复制错误 http://www.linuxidc.com/Linux/2013-04/83091.htm如何查看Oracle数据库的session阻塞 http://www.linuxidc.com/Linux/2013-01/77199.htmvarchar2转化nvarchar2类型乱码Oracle中收集表与列统计信息相关资讯      Oracle session 
  • Oracle中如何评估真正的并发  (11/11/2015 11:47:53)
  • Oracle 会话(Session)  (06/21/2014 14:03:01)
  • 如何查看Oracle数据库的session阻  (01/01/2013 09:11:15)
  • 当Oracle Session被锁死的时候  (11/21/2014 14:38:55)
  • Oracle 彻底 kill session  (06/21/2013 06:10:49)
本文评论 查看全部评论 (0)
表情: 姓名: 字数