Chinaunix首页 | 论坛 | 博客
  • 博客访问: 245322
  • 博文数量: 50
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 533
  • 用 户 组: 普通用户
  • 注册时间: 2015-07-28 21:56
个人简介

活着,寻找生存。

文章分类

全部博文(50)

文章存档

2017年(1)

2016年(20)

2015年(29)

我的朋友

分类: Oracle

2015-11-21 17:56:46

  在DBA运维中我们经常会遇到连接数突增和SQL执行效率不高导致数据库负载拉高,在业务允许的情况下我们就会去批量KILL SESSION了:

 按用户kill session:
  
BEGIN
  FOR x IN (SELECT sid,serial# FROM v$session WHERE username='&用户名') LOOP
    EXECUTE IMMEDIATE 'ALTER SYSTEM KILL SESSION '''||x.sid ||','||x.serial#||'''';
  END LOOP;
END;
/

按SQL_ID kill session:

BEGIN
  FOR x IN (SELECT sid,serial# FROM v$session WHERE sql_id='&sql_id') LOOP
    EXECUTE IMMEDIATE 'ALTER SYSTEM KILL SESSION '''||x.sid ||','||x.serial#||'''';
  END LOOP;
END;
/

注意:使用上述脚本,需在业务允许情况下执行。
阅读(1930) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~