关于SPOOL(SPOOL是SQLPLUS的命令,不是SQL语法里面的东西。)

对于SPOOL数据的SQL,最好要自己定义格式,以方便程序直接导入,SQL语句如:

select taskindex||'|'||commonindex||'|'||tasktype||'|'||to_number(to_char(sysdate,'YYYYMMDD')) from ssrv_sendsms_task;

spool常用的设置

set colsep' ';    //域输出分隔符

set echo off;    //显示start启动的脚本中的每个sql命令,缺省为on

set feedback off;  //回显本次sql命令处理的记录条数,缺省为on

set heading off;   //输出域标题,缺省为on

set pagesize 0;   //输出每页行数,缺省为24,为了避免分页,可设定为0。

set termout off;   //显示脚本中的命令的执行结果,缺省为on

set trimout on;   //去除标准输出每行的拖尾空格,缺省为off

set trimspool on;  //去除重定向(spool)输出每行的拖尾空格,缺省为off

导出文本数据的建议格式:

SQL*PLUS环境设置SET NEWPAGE NONE

SET HEADING OFF

SET SPACE 0

SET PAGESIZE 0

SET TRIMOUT ON

SET TRIMSPOOL ON

SET LINESIZE 2500

注:LINESIZE要稍微设置大些,免得数据被截断,它应和相应的TRIMSPOOL结合使用防止导出的文本有太多的尾部空格。但是如果LINESIZE设置太大,会大大降低导出的速度,另外在WINDOWS下导出最好不要用PLSQL导出,速度比较慢,直接用COMMEND下的SQLPLUS命令最小化窗口执行。

对于字段内包含很多回车换行符的应该给与过滤,形成比较规矩的文本文件。通常情况下,我们使用SPOOL方法,将数据库中的表导出为文本文件的时候会采用两种方法,如下述:

方法一:采用以下格式脚本

set colsep '|'               --设置|为列分隔符

set trimspool on

set linesize 120

set pagesize 2000

set newpage 1

set heading off

set term off

set num 18

set feedback off

spool 路径+文件名

select * from tablename;

spool off

方法二:采用以下脚本

set trimspool on

set linesize 120

set pagesize 2000

set newpage 1

set heading off

set term off

spool 路径+文件名

select col1||','||col2||','||col3||','||col4||'..' from tablename;

spool off

比较以上方法,即方法一采用设定分隔符然后由sqlplus自己使用设定的分隔符对字段进行分割,方法二将分隔符拼接在SELECT语句中,即手工控制输出格式。

在实践中,发现通过方法一导出来的数据具有很大的不确定性,这种方法导出来的数据再由sqlldr导入的时候出错的可能性在95%以上,尤其对大批量的数据表,如100万条记录的表更是如此,而且导出的数据文件狂大。

而方法二导出的数据文件格式很规整,数据文件的大小可能是方法一的1/4左右。经这种方法导出来的数据文件再由sqlldr导入时,出错的可能性很小,基本都可以导入成功。

因此,实践中我建议大家使用方法二手工去控制spool文件的格式,这样可以减小出错的可能性,避免走很多弯路。

自测例:将ssrv_sendsms_task表中的数据导出到文本(数据库Oracle 9i  操作系统 SUSE LINUX Enterprise Server 9)

spool_test.sh脚本如下:

#!/bin/sh

DB_USER=zxdbm_ismp                               #DB USER

DB_PWD=zxin_smap                                 #DB PASSWORD

DB_SERV=zx10_40_43_133                           #DB SERVICE NAME

sqlplus -s $DB_USER/$DB_PWD@$DB_SERV<

set trimspool on

set linesize 120

set pagesize 2000

set newpage 1

set heading off

set term off

spool promt.txt

select taskindex||'|'||commonindex||'|'||tasktype||'|'||to_number(to_char(sysdate,'YYYYMMDD')) from ssrv_sendsms_task;

spool off

EOF

执行./spool_test.sh后生成sp_test.txt,内容如下:

83|115|1|20080307

85|115|11|20080307

86|115|10|20080307

84|115|2|20080307

6|5|14|20080307

7|5|12|20080307

9|5|15|20080307

注:上面自测例中,spool promt.txt中的目标生成文件promt.txt,在HP-UNX环境下的shell脚本中调用Oracle的spool函数,如果将上述逻辑代码封装为一个function,然后来调用这个function的话,则在shell脚本中最终是不会生成promt.txt文件的。只能直接执行逻辑代码,封装后则spool函数失效。

对于promt.txt在相对路径下,下面2中方法在shell环境中执行时,两者只能择一,两者并存则spool函数会失效。假设promt.txt文件生成的路径为:/home/zxin10/zhuo/batchoperate/spoolfile

方式[1]

echo "start spool in shell.."

sqlplus -s zxdbm_ismp/zxin_smap<

set pagesize 0

set echo off feed off term off heading off trims off

set colsep '|'

set trimspool on

set linesize 10000

set trimspool on

set linesize 120

set newpage 1

spool /home/zxin10/zhuo/batchoperate/spoolfile/promt.txt

select batchindex||'|'||productid||'|'||contentid||'|'||optype||'|'||uploadfile from zxdbm_700.s700_batch_operation where status=1;

spool off

EOF

echo "end.."

方式[2]

echo "start spool in shell.."

cd /home/zxin10/zhuo/batchoperate/spoolfile

sqlplus -s zxdbm_ismp/zxin_smap<

set pagesize 0

set echo off feed off term off heading off trims off

set colsep '|'

set trimspool on

set linesize 10000

set trimspool on

set linesize 120

set newpage 1

spool promt.txt

select batchindex||'|'||productid||'|'||contentid||'|'||optype||'|'||uploadfile from zxdbm_700.s700_batch_operation where status=1;

spool off

EOF

echo "end.."

oracle spool 分隔符_Oracle spool 用法小结相关推荐

  1. oracle spool 分隔符_Oracle spool导出数据

    Oracle spool导出数据 freezingsun 2月 7, 2014 Oracle spool导出数据已关闭评论 在工作中,有时需要将表中的数据查询出来,保存成txt格式或者csv格式,以便 ...

  2. oracle @spool,Oracle spool 用法小结

    Oracle spool 用法小结 转自:http://wallimn.javaeye.com/blog/472182 对于SPOOL 数据的SQL,最好要自己定义格式,以方便程序直接导入,SQL语句 ...

  3. oracle spool 分隔符_[整理]:oracle spool 用法

    本文来自iDB Stock:http://www.idb-stock.net/idb/2011/06/01/153.html 1.spool的作用是什么? spool的作用可以用一句话来描述:在sql ...

  4. oracle spool 分隔符_sqlplus--spool命令参数详解

    sqlplus--SPOOL参数详解 Spool是Oracle快速导出数据的工具,是sqlplus的指令,不是sql语法里的东西 一.Spool常用的设置 set arraysize 5000;  / ...

  5. Oracle中TO_DATE格式的使用小结

    Oracle中TO_DATE格式的使用小结 TO_DATE格式(以时间:2007-11-02   13:45:25为例)              Year:               yy two ...

  6. oracle修改分区表的默认空间,Oracle数据库学习_Oracle分区表的分区占用空间为什么是8M?如何修改分区的初始空间?...

    Oracle数据库学习_Oracle分区表的分区占用空间为什么是8M?如何修改分区的初始空间? 现象一描述: 在oracle12c下创建一个分区表T_A_TRADING,新建一个分区P1,P1里没有任 ...

  7. pandas用法小结

    前言 个人感觉网上对pandas的总结感觉不够详尽细致,在这里我对pandas做个相对细致的小结吧,在数据分析与人工智能方面会有所涉及到的东西在这里都说说吧,也是对自己学习的一种小结! pandas用 ...

  8. oracle sql plus 安装教程视频教程,oracle 安装与SQLPLUS简单用法

    一 安装oracle数据库成功之后,会显示相关的数据库信息: 全局数据库名:oracle 系统标识符(SID):oracle 服务器参数文件名:c:\oracle\product\10.2.0\db_ ...

  9. Oracle数据库中SQL语句用法(一)

    Copyright © 2019 @Linyer. All Rights Reserved 下接Oracle数据库中SQL语句用法(二)[点击以查看] 目录 第1章:编写基本的SQL SELECT语句 ...

最新文章

  1. 编写一个函数进行左移或右移的位运算
  2. 如何将VMware ubuntu虚拟机磁盘增长改成自分配(未成功)
  3. python 残差图_python 残差图
  4. subpage新写法
  5. ABAP Netweaver, Hybris Commerce和SAP 云平台的登录认证
  6. Linux集群和自动化维1.4.2 优化Linux下的内核TCP参数以提高系统性能
  7. 使用ActiveMQ –具有故障转移协议的“主/从”配置
  8. linux kill进程后黑屏,Linux中Kill进程的N种方法
  9. 游戏开发使用的各个主流引擎对比
  10. linux python 链接 oracle
  11. OpenCV-Python教程8-图像混合
  12. 计算机体系结构课后答案
  13. WPS文字的字数统计在哪?如何查看当前文档有多少个字?
  14. Python3判断字符中英文数字符号
  15. 毕业设计 基于stm32的居民小区火灾检测报警系统 - 物联网 嵌入式
  16. 算法可以申请专利么_华为突破封锁,对标谷歌Dropout专利,开源自研算法Disout...
  17. wind7计算机控制面板在哪,Win7控制面板在哪打开|win7打开控制面板的小技巧
  18. rar文件ubuntu_如何在Ubuntu上提取RAR文件
  19. Appium+python自动化(三十八) - Appium自动化测试框架综合实践 - 框架简介-助你冲击高薪,迎娶白富美(超详解)...
  20. python熊猫图案_熊猫备忘单–适用于数据科学的Python

热门文章

  1. t3不能登录到服务器 host文件,您好!登陆T3 10.8.1的时候提示我不能登录到服务器,请检查服务器配置:failed:账套号不正确...
  2. 司法考试的C证跟考试语言,法考a证和c证的区别
  3. unsigned char与signed char详解
  4. 为什么这么多人觉得前端开发很难做下去?
  5. 【计算机网络】学习笔记:第五章 传输层【王道考研】
  6. 简单典型二阶系统_2021考研概率必看典型例题
  7. c++ unicode转中文
  8. 【程序猿历程】小时候的味道,水浒卡
  9. 直播星引爆09最火行业,受益公司列表
  10. 教师专业发展及职业道德修养名词解释