Oracle sqlplus中常用的set命令

简介: Oracle sqlplus中常用的set命令 set echo on--设置运行命令是是否显示语句set feedback on--设置显示“已选择XX行”set colsep | --设...
Oracle sqlplus中常用的set命令 

set echo on
--设置运行命令是是否显示语句
set feedback on
--设置显示“已选择XX行”
set colsep |  
--设置列与列之间的分割符号
set pagesize 10
--设置每一页的行数
set serveroutput on
--设置允许显示输出类似dbms_output
set heading on
--设置显示列名
set timing on
--设置显示“已用时间:XXXX”
set time on
--设置显示当前时间
set autotrace on
--设置允许对执行的sql进行分析
set verify off                                   
--可以关闭和打开提示确认信息old 1和new 1的显示. 
set colsep ''                                  
--域输出分隔符
set linesize 4000                        
--输出一行字符个数,缺省为80
set pagesize 0                             
--输出每页行数,缺省为24,为了避免分页,可设定为0。
set num 16(或者set numwidth 16)  
--输出number类型域长度,缺省为10
set trimspool on                           
--去除重定向(spool)输出每行的拖尾空格,缺省为off
set heading off                  
--输出域标题,缺省为on
set feedback off                 
--回显本次sql命令处理的记录条数,缺省为on
set termout off         
--显示脚本中的命令的执行结果,缺省为on
set timing off               
--显示每条sql命令的耗时,缺省为off
set trimout on          
--去除标准输出每行的拖尾空格,缺省为off
set echo off                     
--显示start启动的脚本中的每个sql命令,缺省为on
set termout off; 
必须写在.sql文件中进行。
spool e:a
set termout off 
select * from student;
spool off
Example:
SET TERMOUT OFF
--显示脚本中的命令的执行结果,缺省为on
SET ECHO ON
set echo on
--设置运行命令是是否显示语句
SET SERVEROUTPUT ON
--设置允许显示输出类似dbms_output
spool ....log
...
SET TERMOUT ON
SET ECHO OFF
SHOW ERRORS

SPOOL OFF



1:set echo on:显示文件中的每条命令及其执行结果;

set echo off:不显示文件中的命令,只显示其执行结果。

我们举一个例子,看在SET ECHO OFF,SET ECHO ON条件下的不同结果

先建一个sql文件c.sql(在f:\oracle目录下),里面写select * from bonus;

然后在sql环境下输入以下sql语句:

SQL> set echo off;
SQL> spool f:\oracle\d.sql
SQL> @f:\oracle\c.sql

会出现查询的结果:

ENAME      JOB              SAL       COMM
---------- --------- ---------- ----------
SMITH      CLEAK           3904
ALLEN      SALESMAN
WARD       SALESMAN        3128

然后输入:spool off;

之后,打开d.sql,会看到以下内容:

SQL> @f:\oracle\c.sql

ENAME      JOB              SAL       COMM                                      
---------- --------- ---------- ----------                                      
SMITH      CLEAK           3904                                                 
ALLEN      SALESMAN                                                             
WARD       SALESMAN        3128                                                 


SQL> spool off;

同理,我们可以在echo on的条件下进行测试:

SQL> set echo on;
SQL> spool f:\oracle\e.sql(建一个e.sql文件)
SQL> @f:\oracle\c.sql
SQL> select * from bonus;

查询结果如下:


ENAME      JOB              SAL       COMM                                      
---------- --------- ---------- ----------                                      
SMITH      CLEAK           3904                                                 
ALLEN      SALESMAN                                                             
WARD       SALESMAN        3128                                                 

SQL> spool off;

打开e.sql,我们可以看到如下内容:

SQL> @f:\oracle\c.sql
SQL> select * from bonus;(这一句要特别注意哦,就是我们千辛万苦找到的区别之处)


ENAME      JOB              SAL       COMM                                      
---------- --------- ---------- ----------                                      
SMITH      CLEAK           3904                                                 
ALLEN      SALESMAN                                                             
WARD       SALESMAN        3128                                                 


SQL> spool off;

发现了与d.sql的不同点了吗?是的,多了一句:select * from bonus;



2:term命令:
当和SPOOL命令联合使用时,可以取消SQLPLUS输出,查询结果仅仅存在于假脱机文件中
set term on:查询结果既显示于假脱机文件中,又在SQLPLUS中显示;
set term off:查询结果仅仅显示于假脱机文件中。

SQL> set echo off;
SQL> set term off;
SQL> spool f:\oracle\e2.sql
SQL> @f:\oracle\c.sql(注意这里哦:这时并没有在屏幕上输出c.sql的内容,这就是set term off的用途啦!可以看着前面的例子对比一下,就能看出来啦)
SQL> spool off;



3:set feedback off意思是:不显示返回的行数。

例如:set feedback on时:

SQL> set feedback on;
SQL> spool f:\oracle\e4.sql
SQL> @f:\oracle\c.sql
SQL> spool off;

打开e4.sql,会看到:

SQL> @f:\oracle\c.sql


ENAME      JOB              SAL       COMM                                      
---------- --------- ---------- ----------                                      
SMITH      CLEAK           3904                                                 
ALLEN      SALESMAN                                                             
WARD       SALESMAN        3128                                                 


已选择3行。(这个就是需要注意的地方)



4:set heading off:控制报表不输出字段名称。

如:

SQL> set heading off;
SQL> spool f:\oracle\e5.sql
SQL> @f:\oracle\c.sql
SQL> spool off;

打开e5.sql,会看到如下内容:

SQL> @f:\oracle\c.sql
(注意哦:这里没有字段名称)。

SMITH      CLEAK           3904                                                 
ALLEN      SALESMAN                                                             
WARD       SALESMAN        3128                                                 


已选择3行。


SQL> spool off;


还有一点很重要:

如:你已经set term/echo/feedback off等了,你set heading off就会term/echo,feedback off的情况下进行,如不需要,记得把他们设置为on.


目录
相关文章
|
4月前
|
运维 Oracle 前端开发
Oracle 11g RAC集群日常运维命令总结
Oracle 11g RAC集群日常运维命令总结
112 2
|
4月前
|
SQL 运维 Oracle
入门级Oracle 11g日常运维命令总结
入门级Oracle 11g日常运维命令总结
183 1
|
5月前
|
NoSQL Redis
Redis set数据类型命令使用及应用场景使用总结
Redis set数据类型命令使用及应用场景使用总结
55 1
|
4月前
|
SQL 缓存 NoSQL
【Azure Redis 缓存】使用Azure Redis服务时候,如突然遇见异常,遇见命令Timeout performing SET xxxxxx等情况,如何第一时间查看是否有Failover存在呢?
【Azure Redis 缓存】使用Azure Redis服务时候,如突然遇见异常,遇见命令Timeout performing SET xxxxxx等情况,如何第一时间查看是否有Failover存在呢?
|
6月前
|
SQL Oracle 关系型数据库
探索 Linux 命令 `db_archive`:Oracle 数据库归档日志的工具
探索 Linux 中的 `db_archive`,实际与 Oracle 数据库归档日志管理相关。在 Oracle 中,归档日志用于恢复,当在线重做日志满时自动归档。管理员可使用 SQL*Plus 查看归档模式,通过 `RMAN` 进行备份和恢复操作。管理归档日志需谨慎,避免数据丢失。了解归档管理对 Oracle 管理员至关重要,确保故障时能快速恢复数据库。
|
5月前
|
存储 NoSQL Redis
Redis07命令-String类型字符串,不管是哪种格式,底层都是字节数组形式存储的,最大空间不超过512m,SET添加,MSET批量添加,INCRBY age 2可以,MSET,INCRSETEX
Redis07命令-String类型字符串,不管是哪种格式,底层都是字节数组形式存储的,最大空间不超过512m,SET添加,MSET批量添加,INCRBY age 2可以,MSET,INCRSETEX
|
7月前
|
存储 Java Redis
redis-学习笔记(Jedis set 简单命令)
redis-学习笔记(Jedis set 简单命令)
71 1
|
7月前
|
SQL Oracle Unix
Oracle sqlplus failed on AIX platform(/usr/lib/lib
Oracle sqlplus failed on AIX platform(/usr/lib/lib
43 1
|
6月前
|
缓存 NoSQL 关系型数据库
Redis第二课,1.set key value(设置对应的key和value)2.get key(得到value值)Redis全局命令(支持很多的数据结构)3.keys(用来查询当前
Redis第二课,1.set key value(设置对应的key和value)2.get key(得到value值)Redis全局命令(支持很多的数据结构)3.keys(用来查询当前
|
SQL Oracle 关系型数据库

推荐镜像

更多