如何创建Oracle的jobs 以及Procedure

例:在Toad界面下。选择databases->Procedure Editor
//也可以直接在sql界面下执行//也可以直接在isql*plus界面下执行

create procedure bertelsmann as
begin

   INSERT INTO RECORD SELECT CUSSENT.* FROM CUSSENT WHERE ADDDATE<=TO_DATE(to_char(add_months(sysdate,-3),'yyyy-MM-dd hh24:mi:ss'),'yyyy-mm-dd hh24:mi:ss');
 
  DELETE FROM CUSSENT WHERE ADDDATE<=TO_DATE (to_char(add_months(sysdate,-3),'yyyy-MM-dd hh24:mi:ss'),'yyyy-mm-dd hh24:mi:ss');

   COMMIT;

end;

-- 以上创建 一个名为bertelsmann的过程。作用时向表record中插入cussent表中日期小于当前日期三个月的记录
然后删除cussent表中的数据,删除掉刚才插入record(备份表中的数据)

这样一个过程创建 好了。
在Procedures下面能看到我们所创建的过程。。

然后我要让他每三个月执行一次该备份的功能

declare v_job number:=1;

begin

dbms_job.submit(v_job,'bertelsmann;',sysdate,'sysdate+1/1440');

commit;

end;

--解释一下上面的程序

程序主体有四个参数,分别意为:v_job是计划任务号,'bertelsmann;'是计划任务名,如果是多个计划任务,就都用分号隔开,

第三个sysdate意为立即执行此任务,第四个参数是间隔时间的设置,此处为每分钟执行一次,1/1440=1/24/60。


以下转载:

查看任务:select * from user_jobs;select * from all_jobs;

查看正在运行的任务(不推荐使用,速度慢):select * from dba_jobs_running;

另外值得一提的是,在安装oracle配置的时候,有这么一个参数:

job_queue_processes=4  (默认4)

这个参数是定义当前最多可同时运行几个job,它的最大值能设置为36。

除了submit参数外,其余的几个参数有:

        dbms_job.run(v_job);         //运行job

        dbms_job.broken(v_job,true,next_date);        //停止一个job,里面参数true也可是false,next_date(某一时刻停止)也可是sysdate(立刻停止)。

        dbms_job.remove(v_job);        //删除某个job

        dbms_job.what(v_job,'sp_fact_charge_code;');        //修改某个job名

        dbms_job.next_date(v_job,sysdate);        修改下一次运行时间

例题,设定每天2:10:10运行

trunc(sysdate)+2/24+10/24/60+10/24/60/60        //运行时间

trunc(sysdate)+1+2/24+10/24/60+10/24/60/60        //间隔运行时间

例题,设定每月2号的2:10:10运行

trunc(sysdate,'mm')+1+2/24+10/24/60+10/24/60/60        //运行时间

trunc(add_mouths(sysdate,1),'mm')+1+2/24+10/24/60+10/24/60/60           //间隔运行时间

例题,设定每个季度……

trunce(sysdate,'Q')+1+2/24+10/24/60+10/24/60/60         //运行时间

trunce(add_mouths(sysdate,3),'Q'))+1+2/24+10/24/60+10/24/60/60         //间隔运行时间

另外年为'Y;

例题,设定每周一……

next_day(sysdate'星期一')
 

你可能感兴趣的:(oracle,Date,delete,insert,任务,jobs)