**背景:**客户提出一个需求,写SQL脚本的时候,内容是拼接的,如何将这个拼接SQL执行的结果取出来调用执行呢? 我想到的方案是先把结果取出来,存为一个中间文件,再调用该文件便可。 **知识点:**如何将sqlplus结果中的无关信息都去掉? 可使用sqlplus -s进入调用拼接SQL脚本,脚本中配合使用set设定相关属性便可实现。下面举一个简单的示例来讲明:sql
<h1 id="1">1.拼接SQL脚本</h1> 我这里拿拼接一个杀掉业务用户JINGYU的全部会话举例:session
[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
<h1 id="2">2.生成中间文件</h1> 调用上面的拼接SQL脚本,生成中间文件exec.sql:oracle
[oracle@db10 ~]$ sqlplus -s / as sysdba @test.sql > exec.sql
此时查看生成的sql文件,能够确认没有其余内容,知足直接后期调用执行的要求:code
[oracle@db10 ~]$ cat exec.sql alter system disconnect session '148,48' immediate; alter system disconnect session '159,83' immediate;
<h1 id="3">3.调用中间文件</h1> 我这里直接执行调用中间文件验证,根据你的需求也能够将其封装到另外一个脚本中。orm
[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>