设置sqlplus不显示除查询结果外的信息

背景:客户提出一个需求,写SQL脚本的时候,内容是拼接的,如何将这个拼接SQL执行的结果取出来调用执行呢?
我想到的方案是先把结果取出来,存为一个中间文件,再调用该文件即可。
知识点:如何将sqlplus结果中的无关信息都去掉?
可以使用sqlplus -s进入调用拼接SQL脚本,脚本中配合使用set设定相关属性即可实现。下面举一个简单的示例来说明:

1.拼接SQL脚本

我这里拿拼接一个杀掉业务用户JINGYU的所有会话举例:

[oracle@db10 ~]$ cat test.sql 
--format
set heading off
set echo off
set flush off
set feedback off
set pagesize 9999
set linesize 9999
set long 9999

--SQL
--kill_all_session
select 'alter system disconnect session '''||sid||','||serial#||''''||' immediate;' from v$session where username = 'JINGYU';

--exit
exit

2.生成中间文件

调用上面的拼接SQL脚本,生成中间文件exec.sql:

[oracle@db10 ~]$ sqlplus -s / as sysdba @test.sql > exec.sql

此时查看生成的sql文件,可以确认没有其他内容,满足直接后期调用执行的要求:

[oracle@db10 ~]$ cat exec.sql

alter system disconnect session '148,48' immediate;
alter system disconnect session '159,83' immediate;

3.调用中间文件

我这里直接执行调用中间文件验证,根据你的需求也可以将其封装到另一个脚本中。

[oracle@db10 ~]$ sqlplus / as sysdba

SQL*Plus: Release 10.2.0.4.0 - Production on Tue Jul 17 12:01:12 2018

Copyright (c) 1982, 2007, Oracle.  All Rights Reserved.


Connected to:
Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

SYS@orcl> @exec

System altered.


System altered.

SYS@orcl> 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值