并发程序执行sql loader

本文介绍了一种在Oracle ERP环境中通过编写Shell脚本并结合SQLLoader实现数据导入的方法。具体步骤包括:创建临时表存放CSV数据,使用Shell脚本调用SQLLoader导入数据到临时表,再通过自定义的Procedure将数据迁移到接口表,最后执行Import请求将数据正式导入到基表中。

8,创建临时表

9,csv数据文件

10,ctl文件

30,shell文件

40,注册executable

50,注册program

60,挂到相应职责上的request group上

70,在此职责上执行此请求,把源数据导入到临时表中

---------------------------------------------------------------

85,执行自己写的procedure,把数据从临时表导入到标准接口表中

---------------------------------------------------------------

90,执行import 请求,把数据导入到基表中

---------------------------------------------------------------

 

csv-------sqlldr---------->temporary_table-------package------>interface_table-------------import request--------------->base_table

   

1。将数据导入功能写成一个UNIX Shell,允许接受参数,在其中调用sql loader,这个脚本如何写不是本文的内容
2。比如这个数据导入是总帐模块需要用的,那么通常我们就把这个Shell脚本放在$CGL_TOP/bin目录下,假设脚本的名字的为hostprog.prog,扩展名为prog这是必须的。
3。在相同目录下生成link,注意此处生成的link名称为去掉了prog扩展名的文件名,这同样是必须的。
  link -s $FND_TOP/bin/fndcpesr $CGL_TOP/bin/hostprog
4。在ERP系统中注册Concurrent Program Executable,注意选择Type为host
5。在ERP系统中注册Concurrent Program Define,此时可以设置Shell脚本需要接受的外部参数的默认值。注意,当请求调用脚本的时候,会往脚本中传输4个参数值,依次是 orauser/pwd, userid, username, request_id,分别表示数据库用户/密码,ERP用户ID,ERP用户名,当前请求编号,这是我们在写脚本时可以使用的$1-$4这4个参数,而额外自定义的参数一定要从$5开始。
6。找到需要执行这个脚本的ERP用户所拥有的职责,然后将该Program加入职责的请求组中。
7。切换到相应职责,提交请求  

---------------------------------------------------------------------------------------------

在使用SEQUENCE(MAX,1)时,如果前一条数据导入错误,后面仍会加1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值