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
《小鸟爆破》Birzzle入门攻略
- 4
开心消消乐网址
- 5
龙舟破冰之雪地聚会攻略
- 6
糖尿病治疗的“一二三四”新概念
- 7
培训专员面试注意事项/培训讲师面试技巧及提问
- 8
破冰总动员怎么玩呢?
- 9
★iphone★爆裂的小鸟:Brizzle破冰入门全攻略
- 10
破冰总动员攻略
- 11
闪送单子抢单技巧
- 12
天天象上老师入驻流程
- 13
明明录取了,通知书没有收到怎么办?
- 14
易维帮助台是干什么的
- 15
信用卡纠纷如何处理
- 16
Kittenblock图形化编程案例,录制声音
- 17
用光敏电阻控制声音
- 18
智能猫眼如何修改按铃和报警提示音
- 19
包裹签收后出现问题商家不处理怎么办?
- 20
语音播报器声音怎样更换下载?
- 21
货到付款电子产品不能拆开?
