1:创建临时表,并按一定的数据create table ZXX.TEST_TIME( T_TIME VARCHAR2(50), T_STATUS VARCHAR2(1))插入数据如:insert into ZXX.TEST_TIME values('2013-08-08 00:00:00','0');T_STATUS 初始都为0
2:创建存储过程create or replace procedure pro_import_clmxxas v_now_time number; --记录当前时间 type rec is table of clmxx_3%rowtype;--can not sa.clmxx_3%rowtype; --定义数据类型 recs rec; --申明数组 cursor c_exec_time is select * from zxx.test_time where t_status='0' and rownum < 2;--申明显示游标 type c_clmxx is ref cursor; --申明动态游标 l_c_clmxx c_clmxx;begin v_now_time :=to_number(to_char(sysdate,'hh24')); ----记录当前时间的小时来判断是晚上还是白天 if (v_now_time > 17) or (v_now_time < 7) then for r_exec_time in c_exec_time loop update zxx.test_time set t_status='2' where t_time=r_exec_time.t_time; --锁定正在导入数据,防止后启动存储再次执行 commit; open l_c_clmxx for select * from sa.clmxx_3 where jgsj >= to_date(r_exec_time.t_time,'yyyy-mm-dd hh24:mi:ss') and jgsj < to_date(r_exec_time.t_time,'yyyy-mm-dd hh24:mi:ss')+1; --打开动态游标 while (true) loop fetch l_c_clmxx bulk collect into recs limit 1000;--每次存放1000个记录到数组中 forall i in 1 .. recs.count insert into sa.clmxx values recs(i);--插入数组中的数据 commit; exit when l_c_clmxx%notfound; end loop; close l_c_clmxx; update zxx.test_time set t_status='1' where t_time=r_exec_time.t_time;--更新status状态 commit; end loop; end if;end;
3:创建jobdeclarejob number;begin --每30分钟执行一次 sys.dbms_job.submit(job,'pro_import_clmxx;',sysdate,'sysdate+30/1440');end;job详细信息,参考我的经验:http://jingyan.baidu.com/article/a3761b2bbbdd2f1577f9aa75.html
4:验证以上步骤创建完成之后,一定要验证是否导入数据
- 1
一定时间段内并发导入数据(oracle动态游标使用)
- 2
17美吧(一起美吧)打造美唇享受甜蜜爱情的味道
- 3
标致307收音机怎么拆
- 4
如何使用车载霾表检测车内空气质量?
- 5
好煮妇如何看“脸色”做菜-蒜蓉马齿菜
- 6
冬天皮肤干燥的话怎么办
- 7
怎样安装行车记录仪
- 8
皮肤干燥应该用什么护肤品?
- 9
干燥皮肤保湿方案
- 10
花千骨电脑版安装攻略
- 11
冬天皮肤干燥如何处理
- 12
皮肤干燥怎么办
- 13
该如何保养行车记录仪经验详解
- 14
车置换怎么置换的
- 15
行车记录仪如何选购之分辨率
- 16
在选择雅思一对一班时,应该看什么?
- 17
安卓版学为贵雅思如何进行充值?
- 18
大众凌度1.4T的变速箱油在哪里加
- 19
凌度车门外压条怎么拆卸
- 20
凌度的后视镜怎么拆卸
- 21
凌度的前保险杠怎么拆卸
