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/[email protected]: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/[email protected]:1521/ORCL log=l2.log control=l2.ctl streamsize=25600000
    echo "sqlldr1 end"

  exit

  EOF

}

im_data

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

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


发布了40 篇原创文章 · 获赞 26 · 访问量 31万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章