免费注册 查看新帖 |

ChinaUnix.net

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 6004 | 回复: 2

[求助] 求教一个自动删除oracle用户连接的脚本 遇到的问题! [复制链接]

论坛徽章:
1
寅虎
日期:2014-05-22 14:29:28
发表于 2018-06-05 09:27 |显示全部楼层
RT 想写一个shell脚本定时删除oracle用户。因为脚本删除用户直接执行drop语句肯定是不行的,会提示用户在连接状态。

我手动执行的删除步骤如下:
1、查询V$SESSION表中指定ORACLE用户的连情况,并用select语句生成现成的删除session连接的alter语句
2、执行alter语句
3、drop 指定ORACLE用户

我的难点在于,脚本中如何写才获取并执行删除的session连接语句。

求教各位大佬。


论坛徽章:
0
发表于 2018-06-07 14:05 |显示全部楼层
  1. #!/bin/bash

  2. export ORACLE_SID=pdb
  3. export ORACLE_BASE=/u01/app/oracle
  4. export ORACLE_HOME=/u01/app/oracle/product/12.2.1/db_1

  5. sqlplus -s / as sysdba << EOF > killuser`date +%Y%m%d-%H%M%S`.log
  6. set heading off
  7. set feedback off
  8. spool killsession.sql
  9. select 'alter system kill session '''||sid||','||serial#||''';'
  10. from v\$session where username in ('C##SCOTT1');  
  11. spool off
  12. ---------------------------
  13. start killsession.sql
  14. ---------------------------
  15. exit;
  16. EOF
复制代码


是这个效果吗?

论坛徽章:
1
寅虎
日期:2014-05-22 14:29:28
发表于 2018-06-08 11:08 |显示全部楼层
看上去是的,我去测试一下。
谢谢大佬
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

基于案例的 SQL 优化实战训练营

讲师:中电福富特级专家梁敬彬,参与本次课程培训,你将收获:
1. 能编写出较为高效的 SQL;
2. 能解决70%以上的数据库常见优化问题;
3. 能得到老师提供的高效的相关工具和解决方案;
4. 能举一反三,收获不仅仅是 SQL 优化。
现在购票享受8.8折优惠!
----------------------------------------
优惠时间:2019年3月20日前

大会官网>>
  

北京盛拓优讯信息技术有限公司. 版权所有 16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122
中国互联网协会会员  联系我们:huangweiwei@it168.com
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP