Oracle sqlplus中常用的set命令 set echo on
--设置运行命令是是否显示语句set feedback on--设置显示“已选择XX行”set colsep | --设置列与列之间的分割符号set pagesize 10--设置每一页的行数set serveroutput on--设置允许显示输出类似dbms_outputset 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 --输出一行字符个数,缺省为80set pagesize 0 --输出每页行数,缺省为24,为了避免分页,可设定为0。set num 16(或者set numwidth 16) --输出number类型域长度,缺省为10set trimspool on --去除重定向(spool)输出每行的拖尾空格,缺省为offset heading off --输出域标题,缺省为onset feedback off --回显本次sql命令处理的记录条数,缺省为onset termout off --显示脚本中的命令的执行结果,缺省为onset timing off --显示每条sql命令的耗时,缺省为offset trimout on --去除标准输出每行的拖尾空格,缺省为offset echo off --显示start启动的脚本中的每个sql命令,缺省为onset termout off; 必须写在.sql文件中进行。spool e:aset termout off select * from student;spool offExample:SET TERMOUT OFF--显示脚本中的命令的执行结果,缺省为onSET ECHO ONset echo on--设置运行命令是是否显示语句SET SERVEROUTPUT ON--设置允许显示输出类似dbms_outputspool ....log...SET TERMOUT ONSET ECHO OFFSHOW ERRORSSPOOL 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.