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
我执是什么意思?我执是怎么来的?怎么去除我执
- 3
导演、制片人和出品人有什么区别
- 4
和平精英里面哪里可以打僵尸?
- 5
缺少目标感?前途未卜?你可能需要职场这七问!
- 6
和平精英丧尸模式怎样能让丧尸攻击不到自己呢?
- 7
中国经典国学之宝宝读书2015-10-23
- 8
古月方源为什么叫大爱仙尊
- 9
KTV必备曲目NO.5
- 10
为人处事做最好的自己
- 11
情天恨海半世缘是哪年拍的
- 12
暗夜危机,对于穿墙僵尸的打击攻略
- 13
意式香草烤鸡的步骤
- 14
你身边的IT男是怎样的
- 15
笑果文化4个创始人是什么
- 16
2020年新兴职业
- 17
如何分辨编剧业谣言?
- 18
僵尸需要脑浆2小游戏第二十八关攻略
- 19
拔冗一见是什么意思呢
