数据迁移:spool命令

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


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/14683446/viewspace-670334/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/14683446/viewspace-670334/

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值