温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

定时执行存储过程

发布时间:2020-06-08 05:40:40 来源:网络 阅读:910 作者:Mr_Dai 栏目:关系型数据库

定时执行存储过程

基础

  • Oracle定时器

Oracle定时器:定时执行某个存储过程。

通过pl/SQL的图形化界面可以看到。定时器包括:调度和存储过程连接口

定时执行存储过程

 

  • 存储过程连接口

存储过程连接口,主要告诉定时器要执行哪一个存储过程。存储过程连接口就是存储过程执行的入口。从图形化界面可以看出“Action”就是要执行的存储过程。而“Arguments”就是调用该存储过程所需要的参数类型及存储过程所调用的必须参数。

定时执行存储过程

  • 存储过程

存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程。

  • 调度

调度最主要的功能就是告诉定时器神什么时候执行定时任务,执行的任务的频率是多久。

 

 定时执行存储过程

案件脚本的创建

/* 创建可执行程序 */
begin
    DBMS_SCHEDULER.CREATE_PROGRAM(
        program_name       
=>'peace_sj_his.PROG_DATASYNC',
        program_action     
=>'peace_sj_his.P_DATASYNC',
        program_type       
=>'STORED_PROCEDURE',
        number_of_arguments
=>3,
        comments           
=>'数据同步程序',
        enabled            
=> false
    );
end;
/

/* 设置可执行程序的输入参数 */
begin
    DBMS_SCHEDULER.define_program_argument(
        program_name     
=>'peace_sj_his.PROG_DATASYNC',
        argument_position
=>1,
        argument_type    
=>'VARCHAR2',
        default_value    
=>''
    );
    DBMS_SCHEDULER.define_program_argument(
        program_name     
=>'peace_sj_his.PROG_DATASYNC',
        argument_position
=>2,
        argument_type    
=>'VARCHAR2',
        default_value    
=>''
    );
    DBMS_SCHEDULER.define_program_argument(
        program_name     
=>'peace_sj_his.PROG_DATASYNC',
        argument_position
=>3,
        argument_type    
=>'VARCHAR2',
        default_value    
=>''
    );
END;
/

/* 创建调度表 */
begin
    DBMS_SCHEDULER.create_schedule(
        schedule_name  
=>'peace_sj_his.SCH_DATASYNC',
        repeat_interval
=>'FREQ=MINUTELY;INTERVAL=2',
        start_date     
=> sysdate,
        comments       
=>'数据同步调度'
    );
end;
/

/* 创建作业 */
begin
    DBMS_SCHEDULER.create_job(
        job_name     
=>'peace_sj_his.JOB_PPTN',    
        program_name 
=>'peace_sj_his.PROG_DATASYNC',
        schedule_name
=>'peace_sj_his.SCH_DATASYNC',
        job_class    
=>'DEFAULT_JOB_CLASS',           
        comments     
=>'雨量数据同步作业',
        auto_drop    
=> false,
        enabled      
=> false
    );
end;
/

/* 启动可执行程序 */
exec DBMS_SCHEDULER.enable('PROG_DATASYNC');

/* 启动作业 */
exec DBMS_SCHEDULER.enable('JOB_PPTN');

/* 设置不同的作业参数 */
begin
    DBMS_SCHEDULER.SET_JOB_ARGUMENT_VALUE(
        job_name         
=>'peace_sj_his.JOB_PPTN',
        argument_position
=>1,
        argument_value   
=>'ST_PPTN_R'
    );
    DBMS_SCHEDULER.SET_JOB_ARGUMENT_VALUE(
        job_name         
=>'peace_sj_his.JOB_PPTN',
        argument_position
=>2,
        argument_value   
=>'TM'
    );
    DBMS_SCHEDULER.SET_JOB_ARGUMENT_VALUE(
        job_name         
=>'peace_sj_his.JOB_PPTN',
        argument_position
=>3,
        argument_value   
=>'STCD'
    );
end;
/
----Job管理-----------------------------------------------------------------------

/* 禁用Job */
exec dbms_scheduler.disable('JOBTEST');
/* 执行Job */
exec dbms_scheduler.run_job('JOBTEST');
/* 停止Job */
exec dbms_scheduler.stop_job('JOBTEST');
/* 删除Job */
exec dbms_scheduler.drop_job('JOBTEST');

 

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI