美文网首页
定时执行存储过程

定时执行存储过程

作者: barry_di | 来源:发表于2017-02-11 22:02 被阅读0次

一、基础

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

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

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

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

二、脚本展示

1、创建可执行程序

    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;```

###2、设置可执行程序的输入参数
```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;

3、创建调度表

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

4、创建作业

    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;

5、启动可执行程序

exec DBMS_SCHEDULER.enable('PROG_DATASYNC');

6、启动作业

exec DBMS_SCHEDULER.enable('JOB_PPTN');

7、设置不同的作业参数

    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、Oracle定时器Oracle定时器:定时执行某个存储过程。通过pl/SQL的图形化界面可以看到。定...

  • 查询job和sql的执行情况

    参考链接 oracle job 定时执行 存储过程 Oracle job procedure 存储过程定时任务 O...

  • oracle 定时执行存储过程

    这个定时是执行一个存储过程的, DECLARE JOB BINARY_INTEGER; --任务ID v...

  • mysql 存储过程和事件总结

    任务需求:定时执行的任务,调用存储过程,进行数据迁移。 存储过程相关总结:(存储过程的创建 不能伴随有if exi...

  • mysql定时器,创建定时任务

    查看定时器功能开启状态 查看指定定时器状态 创建测试表 定时器创建(定时器可以直接执行语句也可以执行存储过程的调用)

  • SQL简单使用

    创建存储过程 创建定时任务 以下命令是在PLSQL是命令窗口中执行

  • mysql创建定时执行存储过程任务

    sql语法很多,是一门完整语言。这里仅仅实现一个功能,不做深入研究。 目标:定时更新表或者清空表。 案例:曾经做过...

  • mysql存储过程+事件 执行定时任务

    mysql怎么让一个存储过程定时执行查看event是否开启: show variables like '%sche...

  • MySQL定时任务

    一、查看定时任务是否开启 二、开启关闭定时任务 三、建立定时任务,实例 四、修改事件 注: 其中的存储过程为 执行...

  • MySQL批量添加数据

    创建存储过程 执行存储过程 删除存储过程

网友评论

      本文标题:定时执行存储过程

      本文链接:https://www.haomeiwen.com/subject/bkboittx.html