您好,欢迎访问一九零五行业门户网

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阻塞
其它类似信息

推荐信息