1、dbms_scheduler
Oracle 10g引入dbms_scheduler来替代先前的dbms_job,在功能方面,它比dbms_job提供了更强大的功能和更灵活的机制/管理(引用自百度百科)。这个包主要包括以下几个部分(以下定义均引用自百度百科):
program:程序。
10g下的program支持分为3种形式:PL/SQL BLOCK、STORED_ PROCEDURE、EXECUTABLE。
schedule:调度。
一个任务计划执行的时间策略。比如我们想要创建一个晚上3点执行的任务计划,就可以创建一个调度,凡是符合这个调度要求的,都可以调用这个我们预先创建好的调度。可以用dbms_scheduler.create_schedule来创建一个调度。
job:作业。
一个调度程序作业的实体.可以由dbms_scheduler.create_job创建生成.它可以自行指定作业属性,也可以调用我们预先创建的一系列scheduler、program、chain、job_class、 window、window_group来匹配其作业属性。
job_class:作业类。
定义了运行作业的资源使用者组,通过使用窗口中的资源计划,我们可以在不同资源组和不同作业类之间分配资源。可以使用dbms_scheduler.create_job_class创建一个作业类。
window:窗口。
可以看成是一个更高功能的调度,窗口可以调用系统中存在的调度(也可以自行定义执行时间),而且,具有资源计划限制功能,窗口可以归属于某个窗口组。可以使用DBMS_SCHEDULER.CREATE_WINDOW来创建一个窗口。
window_group:窗口组。
一个/几个窗口的集合。10g默认的自动采集统计信息的调度就是一个窗口组的形式,譬如,设置两个窗口,窗口一指定任务周日、周五晚上12点执行,而窗口二设定周六凌晨3点执行,这两个窗口组成了一个窗口组,形成了这个job的执行调度策略。可以使用DBMS_SCHEDULER.CREATE_WINDOW_GROUP来创建一个窗口组。
chain:链。
链可以看作是一个/几个program/event scheduler的集合,为了维护需要,我们可能需要将很多不同的program放到一起依次执行,按照以前的模式,要么将这几个program能整合成一个大的整体,要么分开几个job来单独执行,这无疑加重了维护负担,而chain的出现,可以优化这个问题,我们将事先定义好的program集合到一起,然后统一制定一个job来执行,可以使用dbms_scheduler.create_chain来创建一个chain。
2、job
由于工作中目前只用到了job,所以就先学job了,其他部分之后再慢慢学,这东西急不得~
2.1 创建job
可以由dbms_scheduler.create_job创建生成。它可以自行指定作业属性,也可以调用我们预先创建的一系列scheduler、program、chain、job_class、window、window_group来匹配其作业属性。
创建job的语法:
sys.dbms_scheduler.create_job(
job_name => ,
job_type => ,
jog_action => ,
number_of_arguments => ,
start_date => ,
repeat_interval => ,
end_date => ,
job_class => ,
enabled => ,
auto_drop => ,
comments =>
);
参数介绍:
job_name:job名字
job_type:job类型,支持三种类型:
1)PLSQL_BLOCK——PL/SQL语句块;
2)STORED_PROCEDURE——存储过程;
3)EXECUTABLE——外部程序(外部程序可以是一个shell脚本,也可以是操作系统级别的指令)。
job_action:根据job_type的不同,job_action有相对应的内容。
number_of_arguments:参数个数。
start_date:执行开始时间。
repeat_interval:指定job执行频率(如每分钟执行一次、每天执行一次等)。
end_date:执行结束时间。
job_class:jobclass的名字。
enabled:指定是否自动激活job,为true代表自动激活,false代表不激活。
auto_drop:执行完是否自动drop
comments:对于job的简单说明
2.2 对job的各种操作
查询:
select owner, job_name, state from dba_scheduler_jobs;
select job_name, state from user_scheduler_jobs;
注意:相应的查询都需要有相对应的权限。
启用:dbms_scheduler.enable('job_name');
运行:dbms_scheduler.run_job('job_name');
停止:dbms_scheduler.stop_job('job_name');
删除:dbms_scheduler.drop_job('job_name')
注意:以上四个操作接口都是有两个参数的,其中第二个参数有默认值,具体含义可以查看以下链接:
http://docs.oracle.com/cd/B28359_01/appdev.111/b28419/d_sched.htm#i1012587
http://docs.oracle.com/cd/B28359_01/appdev.111/b28419/d_sched.htm#i1013568
http://docs.oracle.com/cd/B28359_01/appdev.111/b28419/d_sched.htm#i1009818
http://docs.oracle.com/cd/B28359_01/appdev.111/b28419/d_sched.htm#i1009950
由于本人英语太差,看了很久才大概看明白,但还是不能准确的翻译过来,所以就不在这里翻译了,可能还有地方没理解透彻,如有看懂并理解的朋友,欢迎留言。
3、job应用实例
现在,写一个简单的例子练习一下,加深一下印象。
/*
** 创建一个存储过程,输出当前系统时间
*/
create or replace procedure My_Time
is
begin
dbms_output.put_line(to_char(sysdate, 'yyyy-mm-hh HH24:MI:SS'));
end;
/*
** 创建一个job来调用以上存储过程
*/
declare
n_JobExist integer; --标记job是否存在
s_Job_Name varchar2(32) := 'My_Job';
begin
n_JobExist := 0;
--查询My_Job是否存在,如果存在则先drop掉
begin
select
1
into
n_JobExist
from
user_scheduler_jobs
where
job_name = upper(s_Job_Name);
exception
when NO_DATA_FOUND then
NULL;
end;
if (n_JobExist = 1) then
sys.dbms_scheduler.drop_job(s_Job_Name);
end if;
--创建My_Job
sys.dbms_scheduler.create_job(
job_name => s_Job_Name,
job_type => 'plsql_block',
--要调用的存储过程
job_action => 'begin
My_Time;
end;',
repeat_interval => 'freq=secondly;interval=1',
start_date => sysdate,
--end_date => sysdate + 3/(24*60),
job_class => 'DEFAULT_JOB_CLASS',
auto_drop => false,
enabled => true
);
end;
/
查看结果可以在PL/SQL中找到工具->浏览器->jobs选项,右击My_Job,点查看,其中的‘运行细节’选项就是运行的结果。
4、参考资料
http://docs.oracle.com/cd/B28359_01/appdev.111/b28419/d_sched.htm#CIHHBGGI
http://www.cnblogs.com/lanzi/archive/2012/11/23/2784815.html