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"
检查可知结果符合要求。