SPOOL 命令使用实例【oracle导出纯文本格式文件】

SET echo off              --在用start命令执行一个sql脚本时,是否显示脚本中正在执行的SQL语句;

SET feedback off          --是否回显本次sql命令处理的记录条数,缺省为on;

SET heading  off          --是否显示列标题,缺省为on;

SET pagesize 50000        --设置每页有多少行数,缺省为14。当值设为0时,输出内容为一页且不显示列标题,为了避免分页,我们通常可设定为0。
SET termout off           --是否在屏幕上显示输出的内容,或脚本中的命令的执行结果,缺省为on;

SET trimout on;        --去除标准输出每行后面多余的空格,缺省为off;

SET timing off            --显示每个sql语句花费的执行时间;

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

SET  NULL text            --显示时,用text值代替NULL值;

SET serveroutput off   --是否显示用DBMS_OUTPUT.PUT_LINE包进行输出的信息;--编写存储过程时,大多会将必要的信息输出;

SET newpage none    --设置页与页之间的分隔{1|n|NONE};当值为0时在每页开头有一个小的黑方框;当值为n时在页和页之间隔着n个空行;当为none时,会在页和页之间没有任何间隔;
SET linesize 1000       --设置一行可以容纳的字符数{80|n};输出内容大于设置的行可容纳的字符数,则折行显示.据实际字符设置,过大导出速度慢;
SET wrap on              --输出行长度大于设置行长度时(用set linesize n命令设置);值为on时,多余的字符另起一行显示,否则多余的字符将被切除,不予显示;

SET verify off            --是否显示替代变量被替代前后的语句;

SET  colsep' ';    --域输出分隔符;

------------------------------------------------------------------------------------------------------

导出文本数据的建议格式:
SQL*PLUS环境设置--

SET echo off               --在用start命令执行一个sql脚本时,不显示脚本中正在执行的SQL语句

SET heading  off         --不显示字段的名称

SET pagesize 0          --设置输出每页行数,为了避免分页,可设定为0。设置为0时,输出内容为一页且不显示列标题具有SET heading  off  包含的功能。

SET newpage none    --页与页之间没有分隔                                        
SET trimout on     --去除标准输出每行后面多余的空格
SET trimspool on        --去除重定向(spool)输出每行的拖尾空格
SET linesize 1000       --设置一行可以容纳的字符数

SET feedback off         --是否回显本次sql命令处理的记录条数,缺省为on;

工作运用时导出文本数据的常用格式:

SET echo off

SET pagesize 0

SET feedback off

SET trimout on 

SET trimspool on

SET linesize 1000

spool路径+文件名

需要执行的SQL代码

spool off

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

实例

要求

①导出的过程不在SQL*PLUS屏幕上显示
②导出的文本中不含有执行的SQL命令
③导出的文本中不含有字段名
④导出的文本中使用逗号(英文)作为字段的分隔符
⑤导出的文本中每行长200个字符
⑥导出的文本中每页999行
⑦导出的文本中每行后面的空格必须被截取
编写脚本txt_format.sql

-set部分设置导出的文本格式
set echo off             --关闭脚本中正在执行的SQL语句的显示
set feedback off         --关闭本次sql命令处理的记录条数,默认为on即去掉最后的已经选择的行数
set verify off           --可以关闭和打开提示确认信息
set heading off          --关闭标题的输出设置为off就去掉了select结果的字段名,只显示数据
set term off             --不在屏幕上输出执行结果
set trimspool on         --将每行后面多余的空格去掉【linesize-实际字符数=多余空格】
set trimout on           --去除标准输出每行后面多余的空格
set linesize 200         --设置每行最多显示200个字符
set pagesize 0         --设置每页最多显示999行记录
set termout off          --屏幕不显示查询数据
--@/home/oracle/leonarding/get_table.sql     --设置导出哪个表里的数据和导出的样子,这是第二种方法
spool ls_test.txt      --where <file> is file_name[.ext] [CRE[ATE]|REP[LACE]|APP[END]]
select rnc_id||'|'||rnc_label_cn||'|'||rnc_label_en from rnc;
--只有关闭spool导出操作,才会在输出文件中看到输出内容,这句话不能写在spool off后面会报错
spool off              
exit

注:请注意上面的两个地方:set部分和spool部分,前者用于设置导出的文本格式,后者再次执行一个sql脚本:get_table.sql进行导出。下面我们再看另一个脚本get_table.sql

select rnc_id||'|'||rnc_label_cn||'|'||rnc_label_en from rnc;

那么我们来看一下结果ls_test.txt

876947945|TJRNC04_260|TJRNC04_260
1128405375|TJRNC03_259|TJRNC03_259
1723122318|TJRNC05_261|TJRNC05_261
4290614068|TJRNC06_262|TJRNC06_262
145277785|TJRNC14_270|TJRNC14_270
96954|TJRNC02_258|TJRNC02_258
96956|TJRNC10_266|TJRNC10_266
96907|TJRNC08_264|TJRNC08_264
96926|TJRNC09_265|TJRNC09_265
96930|TJRNC12_268|TJRNC12_268
96932|TJRNC11_267|TJRNC11_267
96934|TJRNC13_269|TJRNC13_269
96946|TJRNC01_257|TJRNC01_257
96948|TJRNC15_271|TJRNC15_271
96950|TJRNC16_272|TJRNC16_272
96952|TJRNC17_273|TJRNC17_273
96906|TJRNC07_263|TJRNC07_263

以下的文章主要介绍的是如何正确的把Oracle数据导出成Txt 的格式,Oracle数据导出成Txt 在实际应用中的比例还是比较常见的,以下的文章主要是对实际操作方案的描述,以下就是正文的主要内容的描述。
Oracle数据库提供的SQL功能很好很强大,用得越多越觉得自己浅薄无知。

上周做系统演示时需要手工制造一些文本数据充当数据源,想偷偷懒就用了Toad工具直接查询后导出成csv格式。今天正好有点时间,整理了一下思路,用sql去实现文本数据的生成。写了大致框架,有空时再来完善吧。

步骤如下:

新建一个sql脚本 d:\czrk.sql,代码如下: SET echo off

  1. SET feedback off
  2. SET newpage none
  3. SET pagesize 50000
  4. SET linesize 20000
  5. SET verify off
  6. SET pagesize 0
  7. SET term off
  8. SET trims ON
  9. SET heading off
  10. SET trimspool ON
  11. SET trimout ON
  12. SET timing off
  13. SET verify off
  14. SET colsep |
  15. spool d:\czrk.txt
  16. SELECT sfzh || ',' || xm || ',' || xb || ',' 
    || csrq || ',' || mz|| ',' || xzqh|| ',' || jzdz FROM m_czrk WHERE rownum<=10000;
  17. spool off

Oracle数据导出成Txt格式:sqlplus连接上数据库,执行脚本

  1. sqlplus dc/dc@mydb;
  2. sqlplus>@d:\czrk.sql

这样就在d盘下生成了一万条数据了。

以上的相关内容就是对把Oracle数据导出成Txt格式的介绍。

SPOOL 命令使用实例【oracle导出纯文本格式文件】的更多相关文章

  1. (转载)DBGridEh导出Excel等格式文件

    DBGridEh导出Excel等格式文件 uses DBGridEhImpExp; {--------------------------------------------------------- ...

  2. 将Mysql的一张表导出至Excel格式文件

    将Mysql的一张表导出至Excel格式文件 导出语句 进入mysql数据库,输入如下sql语句: select id, name, age from tablename into outfile ' ...

  3. 让ASP.NET Web API支持POST纯文本格式(text/plain)的数据

    今天在web api中遇到了这样一个问题,虽然api的参数类型是string,但只能接收post body中json格式的string,不能接收原始string. web api是这样定义的: pub ...

  4. 关于markdown(typora)的操作指南,以及导出为word格式文件插件(pandoc-2.6-windows-x86_64)的下载

    Markdown简介 插件链接文章结尾处 目录 Markdown简介1. Markdown是什么?2. 谁创造了它?3. 为什么要使用它?4. 怎么使用?4.1 标题4.2 段落4.3 区块引用4.4 ...

  5. 利用mysqldump命令导出为csv格式文件

    解决方法: 先导出为txt文件,其内容是以逗号“,”分隔的,得到txt文件后,再自行处理为.csv或者.xls文件. 参数说明: -t, --no-create-info   Don't write ...

  6. 正则表达式实现将html文本转换为纯文本格式(将html字符串转换为纯文本方法)

    Regex regex = new Regex("<.+?>", RegexOptions.IgnoreCase); string strOutput = regex. ...

  7. richtextbox Ctrl+V只粘贴纯文本格式

    只能粘贴剪切板中的TXT内容 并且 不能改变 剪切板的内容1 当用户按下Ctrl+V屏蔽系统的粘贴功能,然后添加自己的功能2019年12月19日 19:34:38 private void richT ...

  8. 将table导出为excel格式文件

    html: <table cellpadding="0" cellspacing="0" class="data_table" id= ...

  9. 【ASP.NET Core】从向 Web API 提交纯文本内容谈起

    前些时日,老周在升级“华南闲肾回收登记平台”时,为了扩展业务,尤其是允许其他开发人员在其他平台向本系统提交有关肾的介绍资料,于是就为该系统增加了几个 Web API. 其中,有关肾的介绍采用纯文本方式 ...

随机推荐

  1. Python之字符串计算(计算器)

    Python之字符串计算(计算器) import re expression = '-1-2*((60+2*(-3-40.0+42425/5)*(9-2*5/3+357/553/3*99/4*2998 ...

  2. 关于解决ssh的"Write failed: Broken pipe"问题

    操作环境: 服务器:微软云 Linux CentOS 虚拟机 客户端:MAC OSX terminal 问题描述: 登录虚拟机短时间内不操作就会断开连接并报该“Write failed: Broken ...

  3. JSONArray 遍历方式

    第一种(java8):遍历JSONArray 拼接字符串 public static void main(String[] args) { JSONArray jSONArray = new JSON ...

  4. Vue页面骨架屏(二)

    实现思路 参考原文中在构建时使用 Vue 预渲染骨架屏一节介绍的思路,我将骨架屏也看成路由组件,在构建时使用 Vue 预渲染功能,将骨架屏组件的渲染结果 HTML 片段插入 HTML 页面模版的挂载点 ...

  5. Vue页面骨架屏(一)

    在开发webapp的时候总是会受到首屏加载时间过长的影响,主流的解决方法是在载入完成之前显示loading图效果,而一些大公司会配置一套服务端渲染的架构来解决这个问题.考虑到ssr所要解决的一系列问题 ...

  6. sql server 数据库 杀掉死锁进程

    use mastergo--检索死锁进程select spid, blocked, loginame, last_batch, status, cmd, hostname, program_namef ...

  7. hihoCoder 必须吐槽hihoCoder的一点 (¯Д¯)ノ

    代码输入窗口太小,mac下经常误操作:双指滑动浏览器后退 而且输入框不会自动保存,一不小心后退一下,啥都..都没了...码了好久的代码就没了..遇到不止一次了 (  ̄ .  ̄ ) (゜ ロ゜;) ( ̄ ...

  8. [BZOJ3196] [Tyvj1730] 二逼平衡树(线段树 套 Splay)

    传送门 至少BZOJ过了,其他的直接弃. 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作: 1.查询k在区间内的排名 2.查询区间内排名为k的值 3.修改某一位值上的 ...

  9. 2018/2/20 Springretry,Feign,以及用通俗的语言(自认为)教会你关于Hystrix的复杂概念

    本来想昨天写的,但临时有事.弄的一晚上都没睡觉,现在头好晕,所以此笔记如果有语言措辞的组织不当,还请见谅:最后,本文可能涉及到大量专业名词,我会尽量用通俗的语句去阐述清楚它们的意思,但如果还是没看懂, ...

  10. 基于端口的信息探测-portscan-1.0

    http://www.tiaozhanziwo.com/archives/174.html