oracle终止session

翻译 2013年12月03日 16:54:48
 
  有时候,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>

相关文章推荐

kill system session(解决oracle死锁)

  • 2011年12月18日 14:49
  • 225B
  • 下载

查询oracle比较慢的session和sql

 --查询最慢的sql select * from ( select parsing_user_id,executions,sorts command_type,disk_reads,...

oracle 中dblink的session不能自动释放

Oracle跨数据库连接dblink的session不能自动释放。 环境: 远数据库A  目标数据库B 目的:在B上建立dblink 连接到A,在B中创建视图,查询A的数据. 问题: 由于B...

清除Oracle中长时间持锁的session

  • 2017年06月17日 16:47
  • 284KB
  • 下载

oracle kill session

  • 2012年01月06日 16:36
  • 57B
  • 下载

oracle系统表v$session、v$sql字段说明

oracle系统表v$session、v$sql字段说明(转) (2011-07-21 16:12:47) 转载 标签: 杂谈 分类: Oracle ...
  • paluo
  • paluo
  • 2011年10月09日 00:47
  • 18099

Oracle 数据库解锁session方式

  • 2013年07月18日 13:24
  • 512B
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:oracle终止session
举报原因:
原因补充:

(最多只允许输入30个字)