将hive中的某张表的数据导入oracle的某张表中

1、将hive中的数据通过hive -e 命令导出到文件中默认分割符为"\t"。

FILE_NAME=`echo " file.del|select * from table"  | awk -F'\|' '{print $1}' `;

Sql=`echo "file.del|select * from table " | awk -F'\|' '{print $2}'`;

hive -e  "$Sql" > "$FILE_NAME"

2、通过iconv -f UTF-8 -t GB18030 file.del>file.del.bak处理文件编码格式

因为hive导出的文件编码格式为UTF-8,这里转换为GB18030。为什么需要转换为GB18030

请参考:https://blog.csdn.net/SpeWong/article/details/72896523

3、将file.del.bak数据通过sqlload导入oracle。

sqlldr userid=username/password@主机 direct=true control=/../table.ctl log=table.log errors=1000 rows=100000

注意导入时配置文件/../table.ctl

unrecoverable
load data
infile '/../file.del.bak'
truncate into table table
fields terminated by "\t" OPTIONALLY ENCLOSED BY '"'
TRAILING NULLCOLS
(
timest

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值