Oracle 多进程
来源:互联网 发布:知乎每日精选接口 编辑:程序博客网 时间:2024/06/16 22:35
因业务表在数据转换时,相应的标识符没有加上,故需多进程对同一张表操作,从而提高更新的效率。
1、写好相应的存储过程:
create or replace procedure proc_update_XXX(being_num in integer,end_num in integer) is cursor c_table is select * from( select a.*, row_number() over(order by rowid) rk from table a) where rk>being_num and rk<=end_num; v_table c_table%rowtype; i integer; begin i := 0;... end;
1、写好相应的存储过程:
2、多进程:使用DBMS_SCHEDULER.CREATE_JOB实现
相应的存储过程如下:(也可以改写成匿名快来执行)
create or replace procedure PROC_JOB_XXX ISV_MAX_THREAD INTEGER;STR_JOB VARCHAR2(500);PRM_HAD_UPDATE VARCHAR2(20);PRM_HAD_UPDATE_1 integer;PRM_HAD_UPDATE_2 integer;BEGIN V_MAX_THREAD := 8;--进程数目 select V_HAD_NUM INTO PRM_HAD_UPDATE from TMEMP_HADUPDATE_LCM_20140124;--已更新的数目 FOR X IN 0 .. V_MAX_THREAD-1 LOOP PRM_HAD_UPDATE_1 := PRM_HAD_UPDATE +X*100; PRM_HAD_UPDATE_2 := PRM_HAD_UPDATE +(X+1)*100; STR_JOB := 'DECLARE BEGIN proc_update_XXX('''|| PRM_HAD_UPDATE_1 ||''' ,''' ||PRM_HAD_UPDATE_2 ||''' ); END;'; DBMS_SCHEDULER.CREATE_JOB(JOB_NAME => 'UPDATE_XXX_THREAD_' || X, JOB_TYPE => 'PLSQL_BLOCK', JOB_ACTION => STR_JOB, ENABLED => FALSE, AUTO_DROP => TRUE, COMMENTS => 'proc_update_XXX_' || X); DBMS_SCHEDULER.ENABLE(NAME => 'UPDATE_XXXX_THREAD_' || X); UPDATE TMEMP_HADUPDATE_LCM_20140124 SET V_HAD_NUM =PRM_HAD_UPDATE + 100 *V_MAX_THREAD; COMMIT;END;
1、写好相应的存储过程:
0 0
- Oracle 多进程
- oracle进程
- Oracle进程
- oracle进程
- oracle进程
- oracle进程
- oracle 进程
- Oracle进程
- ORACLE 进程
- Oracle进程
- Oracle进程--服务器进程
- Oracle 多进程更新同一个表
- perl 多进程抽取oracle数据
- ORACLE体系结构-ORACLE进程简介
- oracle 进程说明
- oracle后台进程
- oracle杀死死锁进程
- ORACLE数据库进程简介
- PAT1027 Colors in Mars (20)
- C_C++ 各种计时函数
- [Java]日志系统
- 从今天开始“机器学习实战”!
- exists&&in
- Oracle 多进程
- JavaFX文档(3)开始JavaFX之旅——1 Hello World
- SQLServer(MSSQL)、MySQL、SQLite、Access相互迁移转换工具 DB2DB v1.1
- Java SE 学习---内存管理&函数参数传递
- 装饰设计模式小计
- oracle 10g+centos/rhel5安装
- mysql 语句记录一下
- 条件判断
- ARM 启动及工作模式切换