挖数不易Oracle

sqlplus文件操作命令

2017-08-03  本文已影响145人  thinkact

1.save 保存文件

save [file]file_name [create|replace|append]
create: --创建文件
replace: --替换文件
append: --附加到文件,如果file_name文件存在,则将缓存区的内容附加到file_name文件后,若不存在,则创建

2.start 执行文件

start file_name; --执行文件中的命令

3.spool 导出到文件

spool 路径+文件名 --导出sqlplus屏幕内容到文件
spool off --停止导出

要输出符合要求格式的数据文件只需在select时用字符连接来规范格式。比如有如下表

SQL>; select id,username,password from myuser;//测试表
1 John       1234
2 Jack       12345
3 Rose       2345
4 Joe        384657
5 Tom        384655
6 Jordan     384455

要输出符合1,John,1234,这样的数据格式就用这样的语句:

SQL>; select id||','||username||','||password||',' from myuser;
1,John,1234,
2,Jack,12345,

写个下面这样的脚本就行可以输出符合要求格式的数据至文件中,不会含有其它不需要东西,只有数据部分。

--脚本文件名为expmyusr.sql,存数据的文件名为e:\exp.txt

set echo on            --是否显示执行的命令内容  
set feedback off       --是否显示 *   rows   selected  
set heading off        --是否显示字段的名称
set verify off         --是否显示替代变量被替代前后的语句。fil
set trimspool off      --去字段空格
set pagesize 1000      --页面大小
set linesize 50//linesize设定尽量根据需要来设定,大了生成的文件也大
define fil= 'e:\exp.txt'
prompt *** Spooling to &fil
spool &fil
select id||','||username||','||'"'||password||'"' from myuser;
spool off;

--执行过程
SQL>; @e:\expmyusr.sql
*** Spooling to e:\exp.txt
1,John,"1234"
2,Jack,"12345"
3,Rose,"2345"
4,Joe,"384657"
5,Tom,"384655"
6,Jordan,"384455"

检查可知结果符合要求。

上一篇 下一篇

猜你喜欢

热点阅读