dbms_scheduler包中job(作业)学习

本文详细介绍了Oracle 10g的dbms_scheduler包,包括program、schedule、job、job_class、window、window_group和chain的概念,并重点探讨了job的创建和操作,提供了一个简单的job应用实例,帮助读者理解和掌握如何在Oracle数据库中设置和管理定时任务。

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://baike.baidu.com/link?url=X3aPKfo7XkHquLLauomJfoSU-Y9KhcJXfGEd_RCwwkB_quYZLv63gSX5YkYkUSki-Ag4gyjI3MfH76klxfS2Ja

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值