• 设置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> 
    
  • 相关阅读:
    [ES6]react中使用es6语法
    [前端自动化]grunt的简单使用
    [react-native]react-native填坑笔记
    [CSS布局]简单的CSS三列布局
    简单说下cookie,LocalStorage与SessionStorage.md
    [算法学习]开始leetcode之旅
    monorepo和multrepo的简介
    异步请求(ajax,http) 之 逐渐完善的大全
    Java中Synchronized的用法
    Node.js小白开路(一)-- fs篇
  • 原文地址:https://www.cnblogs.com/jyzhao/p/9327230.html
Copyright © 2020-2023  润新知