spool命令示例:
以下保存为SQL脚本,在SQLPlus中运行
set echo off set timing off --关闭返回执行时间
set heading off --设置不显示列名
set feedback off --设置不返回选择数据行数
set linesize 320 --设置每行记录字符长度为320字符(1个汉字两个字符)
set pagesize 24 --设置每页行数24条(默认值24)
set newpage 1 --设置新页前1个空行(默认值1)
set trimspool on --设置删除spool写入文件前时输出的尾随空格(默认值OFF)
set termout off --设置屏幕不捕捉、不显示查询结果集(文本文件执行SQL方生效)
spool F:\exp.tsv --spool设置导出文件的完整的路径(包含文件名);此时文件已存在,打开,文件不存在,创建并打开。在执行spool off命令前,不能对该文件进行修改保存。
SELECT '导出的内容' FROM DUAL; --要导出的数据的查询语句
spool off --关闭文件,完成数据导出
spool命令参数详解
set echo <on|off> set timing <on|off>:
开启/关闭返回执行时间;默认值OFF 设置为ON(开启),目前没有发现对执行速度的影响,可忽略。开启后,执行时间将被写入导出文件最后一行。
set heading <on|off>:
开启/关闭每页显示列名;默认值ON 设置为ON(开启),每一页数据都将增加一行列名。开启后,导出文件会增大,降低导出数据的速度(具体增大量与对速度的影响取决于pagesize参数的设置);
set feedback <on|off>:
开启/关闭返回行记录数;默认值ON 设置为ON(开启),目前没有发现对执行速度的影响,可忽略。开启后,执行时间将被写入导出文件最后一行(如果开启返回执行时间,在返回执行时间前两行)。
set linesize <整数:1至32767>:
文本文件每行字符长度(1个汉字占2个字符) 设置的长过大,将影响导出的速度(未测试),过小(小于某条数据与该行所有分隔符字符总数),该条记录将会被拆分成多行。该参数要根据实际表情况进行设定。
set pagesize <整数:0至50000>:
结果集每页记录数;默认值24 设置的越小,文件越大,但对导出大量数据影响不大。因为设置越小,数据相同情况下,空行越多。
set newpage <非负整数>:
新页前空行数;默认值1 默认值为1,每一页前存在1个空行。设置为0,每一页的第一行前存在一个换行符号,没有空行。为保持数据整洁,建议使用默认值1。
set colsep ‘<字符>’:
数据列间隔符 不建议使用该参数,该参数极度影响导出性能(已测试),且导出的文件在SQL Loader中进行数据导入的失败率相当高(未测试)。设置该参数后,导出文件速度与大小成倍增加,具体视数据量而定。建议使用在数据库查询语句中编辑输出格式。
set trimspool <on|off>:
spool写入文件前时是否将输出的尾随空格删除;默认OFF 假设linesize参数设置为300,而某行数据与该行所有分隔符字符总数为200,则该行尾随空格数为100,设置为ON(开启),可以将此类空格删除,减小导出文件大小,提高文件导出速度。
set termout <on|off>:
屏幕是否显示查询数据;默认值ON
设置OFF(关闭,文本文件执行SQL方生效),在导出大量数据时,可以显著提高导出文件的速度。
spool <[文件路径+]文件名>:
spool设置导出文件的完整的路径(包含文件名);以独占方式打开文件。 在文件不存在时,自动创建该文件,并打开;文件存在时,打开该文件。该处打开文件均以独占方式打开,已存在的文件都将被覆盖(原数据将丢失)。
<数据库查询语句>:
要导入文件的数据的查询语句;必须以分号结尾 此处为数据库查询语句,避免使用colsep参数,提高导出性能,建议在此处对导出数据做格式转换。如:SELECT t.OWNER || ',' || t.TABLE_NAME FROM DBA_TABLES t;
文本文件执行该语句或该文件,set termout off命令方生效
spool off:
关闭spool语句,即关闭导出的文件 结束导出操作,关闭导出文件。导出完成