oracle spool生成文件,去掉多余的东西

本文介绍了一种通过SQL命令结合Shell脚本实现从Oracle数据库中导出纯数据的方法。该方法利用`spool`命令将查询结果写入文件,并通过调整命令格式确保输出文件仅包含所需的数据内容。

在网上找了一种方法:

None.gif[oracle@jumper oracle]$ more sp.sql
None.gif
set heading off
None.gif
set feedback off
None.gif
set term off
None.gifspool a.
log
None.gif
@test.sql
None.gifspool 
off
None.gif
exit
None.gif
[oracle@jumper oracle]$ more test.sql
None.gif
select username from dba_users;
None.gif
[oracle@jumper oracle]$ sqlplus -S "/ as sysdba" @sp
None.gif
[oracle@jumper oracle]$ more a.log
None.gifSYS                                                   
None.gifSYSTEM          
None.gifOUTLN           
None.gifSCOTT           
None.gifHAWA            
None.gifCSMIG           
None.gifTEST            
None.gifPERFSTAT        
None.gifMLQIN           
None.gifEYGLE           
None.gifDBSNMP          
None.gifWMSYS           
None.gif
[oracle@jumper oracle]
None.gif

这种方法用SHELL包装时,如果使用下面这种形式:
sqlplus -S "/ as sysdba" <<!
set heading off
set feedback off
set term off
spool a.log
@test.sql
spool off
exit
!
其生成的文件还不是纯数据。只有在shell脚本中使用 sqlplus -S "/ as sysdba" @s.sql (s.sql 就是两个!之间的语句。)
才会生成纯数据。不过这可以使用grep,awk,sed这些工具过滤掉。

转载于:https://www.cnblogs.com/lee/archive/2006/12/26/604168.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值