sqlplus spool 导出文本格式数据

由于项目需要,需要Oracle能够将表的数据格式化到txt文本文件中,然后可以使用其它数据库db2的import,mssql的bcp导入到各自数据库中。

spool 本来是很好用的,但是在格式化数据上 ,不太熟悉set命令,于是网上找了下,在此备注下:

SQL>set colsep' ';     //-域输出分隔符

SQL>set newp none            //设置查询出来的数据分多少页显示,如果需要连续的数据,中间不要出现空行就把newp设置为none,这样输出的数据行都是连续的,中间没有空行之类的

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

SQL> set echo on               //设置运行命令是是否显示语句

SQL> set feedback on;       //设置显示“已选择XX行”

SQL>set feedback off;      //回显本次sql命令处理的记录条数,缺省为on即去掉最后的 "已经选择10000行"

SQL>set heading off;     //输出域标题,缺省为on 设置为off就去掉了select结果的字段名,只显示数据

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

SQL>set linesize 80;      //输出一行字符个数,缺省为80

SQL>set numwidth 12;     //输出number类型域长度,缺省为10

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

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

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

SQL>set serveroutput on;  //设置允许显示输出类似dbms_output

SQL> set timing on;          //设置显示“已用时间:XXXX”

SQL> set autotrace on-;    //设置允许对执行的sql进行分析

set verify off                     //可以关闭和打开提示确认信息old 1和new 1的显示.

 

Oracle 导出数据到文件:
sqlplus /nolog @d:\sp.sql

d:\sp.sql内容如下:
conn system/bizcent@sgtest 
set head off
set headsep off
set newp none
set linesize 100
set pagesize 10000
set sqlblanklines OFF
set trimspool ON
set termout off
set feedback off
spool d:\export.txt
select NODECODE||'&'||NODETYPE||'&'||NODENAME||'&' from "000".tbnode;
spool off
exit
这是我使用的满足了要求

你可能感兴趣的:(sqlplus spool 导出文本格式数据)