oracle使用之--配置化调度任务

需求:管理人员根据需要修改调度任务的执行频率或者其他参数(此处演示频率)

构建存储过程修改调度计划

CREATE OR REPLACE
PROCEDURE change_job 
( p_value in VARCHAR,     --入参
  p_msg out VARCHAR)   is  --出参
BEGIN
 
dbms_job.change ( 
    41, 
    'MOVE_DATA;',   
    SYSDATE + 5/(60*24),
    p_value
);  
 p_msg := '执行成功了';
 EXCEPTION  
    WHEN OTHERS  
    THEN  
      p_msg := '执行出错了';
      DBMS_OUTPUT.PUT_LINE ('Exception happened,data was rollback');  
      ROLLBACK;  
END;

mybatis调用存储过程

<select id="changeTask" statementType="CALLABLE">
	{call change_job(
	#{interval,jdbcType=VARCHAR,mode=IN},
	#{message,jdbcType=VARCHAR,mode=OUT}
	)}
</select>

在dbms_job这个package中还有其他用于操作调度任务的过程:

broken、change、interval、isubmit、next_date、remove、run、submit、user_export、what;

1、broken()过程更新一个已提交的工作的状态,典型地是用来把一个已破工作标记为未破工作。这个过程有三个参数:job 、broken与next_date。 
procedure broken ( 
  job IN binary_integer, 
  broken IN boolean, 
  next_date IN date := SYSDATE 

job参数是工作号,它在问题中唯一标识工作。 
broken参数指示此工作是否将标记为破——true说明此工作将标记为破,而false说明此工作将标记为未破。 
next_date参数指示在什么时候此工作将再次运行。此参数缺省值为当前日期和时间。

job如果由于某种原因未能成功执行,oracle将重试16次后,还未能成功执行,将被标记为broken,重新启动状态为broken的job,有如下两种方式; 
a、利用dbms_job.run()立即执行该job 
begin 
  dbms_job.run(:job) --该job为submit过程提交时返回的job number或是去dba_jobs去查找对应job的编号 
end;

b、利用dbms_job.broken()重新将broken标记为false 
begin 
  dbms_job.broken (:job, false, next_date) 
end;

2、change()过程用来改变指定job的设置。 
这个过程有四个参数:job、what 、next_date、interval。 
procedure change ( 
    job IN binary_integer, 
    what IN varchar2, 
    next_date IN date, 
    interval IN varchar2 

此job参数是一个整数值,它唯一标识此工作。 
what参数是由此job运行的一块PL/SQL代码块。 
next_date参数指示何时此job将被执行。 
interval参数指示一个job重执行的频度。

3、interval()过程用来显式地设置重复执行一个job之间的时间间隔数。 
这个过程有两个参数:job、interval。 
procedure interval( 
    job IN binary_integer, 
    interval IN varchar2 

job参数标识一个特定的工作。 
interval参数指示一个工作重执行的频度。

4、isubmit()过程用来用特定的job号提交一个job。 
这个过程有五个参数:job、what、next_date、interval、no_parse。 
procedure isubmit ( 
    job IN binary_ineger, 
    what IN varchar2, 
    next_date IN date, 
    interval IN varchar2, 
    no_parse IN booean := FALSE 

这个过程与submit()过程的唯一区别在于此job参数作为IN型参数传递且包括一个由开发者提供的job号。如果提供的job号已被使用,将产生一个错误。

5、next_date()过程用来显式地设定一个job的执行时间。这个过程接收两个参数:job、next_date。 
procedure next_date( 
    job IN binary_ineger, 
    next_date IN date 

job标识一个已存在的工作。 
next_date参数指示了此job应被执行的日期、时间。

6、remove()过程来删除一个已计划运行的job。这个过程接收一个参数: 
procedure remove(job IN binary_ineger); 
job参数唯一地标识一个工作这个参数的值是由为此工作调用submit()过程返回的job参数的值,已正在运行的job不能删除。

7、run()过程用来立即执行一个指定的job。这个过程只接收一个参数: 
procedure run(job IN binary_ineger) 
job参数标识将被立即执行的工作。

8、使用submit()过程,job被正常地计划。上面以讲述

9、user_export()过程返回一个命令,此命令用来安排一个存在的job以便此job能重新提交。此程序有两个参数:job、my_call。 
procedure user_export( 
    job IN binary_ineger, 
    my_call IN OUT varchar2 

job参数标识一个安排了的工作。 
my_call参数包含在它的当前状态重新提交此job所需要的正文。

10、what()过程应许在job执行时重新设置此正在运行的命令。这个过程接收两个参数:job、what。 
procedure what ( 
    job IN binary_ineger, 
    what IN OUT varchar2 

job参数标识一个存在的工作。 
what参数指示将被执行的新的PL/SQL代码。实现的功能:每隔一分钟自动向getSysDate表中插入当前的系统时间。




猜你喜欢

转载自blog.csdn.net/G_FUTRUE/article/details/80092686
今日推荐