kill_dead_session.txt

来自「手动kill掉inactive session的一个存储过程。」· 文本 代码 · 共 30 行

TXT
30
字号
/*在数据库的操作中,往往会产生死亡进程,需要我们手动kill掉,下面是一个简单的过程
定时kill掉oracle的inactive session
*/



CREATE OR REPLACE PROCEDURE kill_processes IS
v_c_kill varchar2(80);
BEGIN
/*  WARNING: If you use MTS (Shared Server) do not kill Shared
**           server processes
**
*/
   FOR i IN (select sid,serial# from v$session where status='INACTIVE') LOOP
   V_c_kill := 'ALTER SYSTEM KILL SESSION ' ||''''||i.sid||','||i.serial#||'''';
   execute immediate v_c_kill;
   END LOOP;
END kill_processes;



set serveroutput on
set linesize 10000
variable x number;
begin 
   DBMS_OUTPUT.enable(100000);   
   dbms_job.submit(:x,'kill_processes;',sysdate,'sysdate+2/24'); 
   commit;
   dbms_output.put_line(TO_char(:x));
end;

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?