SPOOL Command Usage

This article explains :-

  • Known issues with SPOOL command and

  • Some of the common SET commands used with SPOOL command

SCOPE

This article is intended for SQL*Plus users.

SPOOL command in itself is a simple command. The issues are usually due to

the incorrect SQL*Plus environment setting (like linesize, heading, echo etc).

Following are some of the commands that have an impact of the output from spool.

More information can be found in SQL*Plus User's Guide and Reference documentation.

DETAILS

SET NUMWIDTH XX


E.g. select 345.34 from dual;

set numwidth 2 ===> ##

set numwidth 4 ===> 345

set numwidth 5 ===> 345.3

set numwidth 6 ===> 345.34

set numwidth 10 ===>____345.34 (where _ is a space)

SET NEWPAGE {1|n|None}


Sets the number of blank lines to be printed from the top of each page to

the top title.

0 - places a formfeed at the beginning of each page (including the

first page) and clears the screen on most terminals.

NONE - SQL*Plus does not print a blank line or formfeed between the report

pages.

SET SPACE


Determines the spacing between columns.

E.g. set space 1 ===> Col1_Col2 (_ is a space)

set space 5 ===> Col1_____Col2 (_ is a space)

SET LINESIZE


Determines the length of the line. If the linesize is too small then the

records will wrap around to the next line and the output may not be readable.

SET PAGESIZE


Sets the number of lines per page. If set to 0, then there are no pages.

SET FEEDBACK


Displays the number of records returned by a query when a query selects at

least n records. ON or OFF turns this display on or off. Setting feedback

to zero is equivalent to turning it OFF.

SET HEADING


Controls printing of column headings in reports.

ON prints column headings in reports; OFF suppresses column headings.

SET VERIFY


Lists each line of the command file before and after substitution.

SET TERMOUT


When running a script containing SQL commands and you have spooled the

output and if you do not want to see the output on your screen, you can

also add SET TERMOUT OFF to the beginning of the file and SET TERMOUT ON

to the end of the file.

E.g.

test.sql :

set termout off

spool t.t0

select* from emp;

spool off

exit

When running this file from SQL*Plus using @test.sql, the output will not

be display on the screen.

SET DOCUMENT


After you type DOCUMENT and enter [Return], SQL*Plus displays the prompt

DOC> in place of SQL> until you end the documentation. The "pound"

character (#) on a line by itself ends the documentation. If you have set

DOCUMENT to OFF, SQL*Plus suppresses the display of the block of

documentation created by the DOCUMENT command.

SET SQLPROMPT


If you do not want the SQL*Plus prompt to appear in the spooled file,

change the prompt to blank using set sqlprompt "".

SET TRIMSPOOL


Determines whether SQL*Plus allows trailing blanks at the end of each

spooled line. ON removes blanks at the end of each line. OFF allows

SQL*Plus to include trailing blanks.

E.g.

set numwidth 38

set NEWPAGE 0

set SPACE 0

set LINESIZE 80

set PAGESIZE 0

set FEEDBACK OFF

set HEADING OFF

set verify off

set doc off

set sqlprompt ""

set ECHO OFF

set trimspool on

Spool file not created in correct directory on Windows


Ensure that the SQL*Plus icon on the client PC desktop is created as a

shortcut and has the correct working directory (usually where you want

to create the spool file).

How does spool out know where to print on Unix


Set the following environment variables :

ORACLE_LPARGS='lpr arguments' e.g. -pr printername

ORACLE_LPPROG=/usr/local/bin/lpr'

SQLPATH and SPOOL


The SQLPATH registry entry or environment variable is used for the default

location/search path for stored SQL scripts and is not used for the SPOOL

command. This allows the user to be able to run scripts from SQL*Plus

without specifying a path. SPOOL command does not use this.

相关推荐
AllData公司负责人31 分钟前
【亲测好用】云原生数据平台能力演示
数据库·云原生·开源
VX:Fegn08958 小时前
计算机毕业设计|基于ssm + vue超市管理系统(源码+数据库+文档)
前端·数据库·vue.js·spring boot·后端·课程设计
chipsense8 小时前
电流传感器型号从数据库查询并排序输出到网页的方法
数据库·php·传感器·霍尔电流传感器
踢足球09298 小时前
寒假打卡:2026-01-28
数据库·oracle
麦聪聊数据8 小时前
智慧医疗数据互联互通:使用 QuickAPI 构建实时诊疗数据交换层
数据库·sql·安全
风吹落叶花飘荡8 小时前
2026年mysql数据库迁移(全流程)
数据库·mysql
2301_822382768 小时前
Python上下文管理器(with语句)的原理与实践
jvm·数据库·python
m0_748229998 小时前
Laravel8.X核心功能全解析
开发语言·数据库·php
液态不合群9 小时前
【面试题】MySQL 的索引下推是什么?
数据库·mysql
2301_790300969 小时前
Python深度学习入门:TensorFlow 2.0/Keras实战
jvm·数据库·python