最近学习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是个好东西,可以推荐给大家!