定时执行存储过程
admin
2023-05-11 08:21:14
0

定时执行存储过程

基础

  • 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');

 

相关内容

热门资讯

河南一企业每月给员工父母发“工... 近日,河南一企业每月1日给员工父母发“工资”一事在网上引热议,很多人点赞,更多也是好奇:咋发?发多少...
“90后夫妻同患罕见病瘫痪”引... 近日,一段“90后新婚夫妻同患罕见病瘫痪”的视频在网上流传,引发关注和热议。有网友对夫妻俩的遭遇表示...
北京:每年开放场景空间资源和场... 5月13日,北京市发展改革委、北京市科委、中关村管委会等部门联合发布了《北京市加快推动场景培育和开放...
DAA衡量智能体的时代,云服务... 今年以来,国内外头部云厂商相继上调部分核心产品价格,打破了行业近二十年“只降不升”的惯例。这背后,是...
2026年网络发稿平台权威测评... 引言:数字化浪潮下,网络发稿生态正在经历深刻变革 在信息爆炸的互联网时代,网络空间已成为企业品牌传播...
“小皮球,架脚踢,马兰开花二十... “二八二五六,二八二五七,二八二九三十一……”当短视频里的外国网友惊呼“这是什么暗号”时,有网友笑称...
房子重新装修需要多少钱(房子重... 像新房子装修后的使用寿命大概在15到20年的样子,之后的各种材料都因时间的关系会逐渐老化,看着越来越...
不锈钢橱柜多少一米 具体要看你使用的不锈钢是哪种型号的,因为市面上有很多种型号的不锈钢,当然价钱也有所不同。那么我们普通...
300-300的瓷砖是多少平方 我们在计算平方的时候,都是将长度乘以宽度,所以300×300的瓷砖,这些瓷砖的面积肯定是0.9个平方...
热水器是一直开着省电还是现用现... 一般情况下家用的热水器是现用现烧比较省电,当热水器一直开着时,热水器会一直持续进行烧水工作,这样会比...