oracle的数据导入导出

最近学习oracle数据的操作,主要是导入导出的实现:好多朋友说用exp和imp做导入导出。可是exp和imp不太灵活。单表数据导出,生成文件格式不太好控制。好些ETL系统,数据的抽取,加载。针对oracle,都是通过sqlplus spool导出,sqlldr加载数据。

下面用shell写了两个脚本,对oracle数据的导出和加载进行操作:

导出:用sqlplus spool,但是set的命令很多,网上拷贝吧!,在测试的时候遇到个问题:我在命令行执行spool导出,会把spool的冗余信息一起导到数据文件中,但是放在shell脚本里,就是纯净的数据文件。

#!/bin/bash

#sqlplus -S /nolog > result.log<<EOF

#conn mymis/mymis

sqlplus -S /nolog > result.log<<EOF

conn mymis/mymis@127.0.0.1:1521/ORCL

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.dat
SELECT USER_ID || ',' || USER_NAME || ',' || USER_PASSWORD || ',' || USER_MAIL || ',' || PHONE_NO || ',' || REMARK FROM MYMIS.TB_MYMIS_USER_INFO;
spool off

exit

EOF

导入:采用sqlldr加载,需要配置一个控制文件!shell去读取控制文件就行了。

下面控制文件:

LOAD DATA
INFILE 'd:\export.dat'
badfile 'l2.bad'
Append INTO TABLE MYMIS.TB_MYMIS_USER_INFO_BAK
FIELDS TERMINATED BY ','
TRAILING
(
  USER_ID,
  USER_NAME,
  USER_PASSWORD,
  USER_MAIL,
  PHONE_NO,
  REMARK
)

下面是shell脚本:

#!/bin/bash

im_data()
{

  sqlldr mymis/mymis@127.0.0.1:1521/ORCL log=l2.log control=l2.ctl streamsize=25600000
    echo "sqlldr1 end"

  exit

  EOF

}

im_data

这样就完成了数据的导入导出了!

题外话:windows下面学习unix shell,cygwin是个好东西,可以推荐给大家!


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值