• 金仓数据库KingbaseES数据库管理员指南--18数据库作业调度


    目录

    18.1. 作业调度及其子程序

    18.2. 创建程序

    18.3. 删除程序

    18.4. 创建调度计划

    18.5. 删除调度计划

    18.6. 创建作业

    18.7. 删除作业

    18.8. 运行作业

    18.9. 禁用作业

    18.10. 启用作业

    18.11. 任务的日历表示法

    18.12. 计算符合规则的下一个日期


    您可以使用DBMS_SCHEDULER创建、运行和管理作业。

    注意:

    本章描述了如何使用DBMS_SCHEDULER包来处理Scheduler对象。

    您可以使用DBMS_SCHEDULER包中的子程序来管理常见任务和调度计划。

    创建程序为了告诉调度器要运行什么。

    您可以通过DBMS_SCHEDULER的DROP_PROGRAM删除一个或多个程序。

    您可以通过DBMS_SCHEDULER的CREATE_SCHEDULER创建调度计划。

    您可以通过DBMS_SCHEDULER的DROP_SCHEDULE删除调度计划。

    当您完成了程序和调度计划的创建,意味着可以基于两者创建一个有计划的作业(JOB)。

    当我们不再需要作业时,可以使用DROP_JOB删除一个指定的作业。

    通过调用DBMS_SCHEDULER.RUN_JOB,您可以使用RUN_JOB程序来测试作业或者在调度计划之外运行它。

    您可以通过DBMS_SCHEDULER的DISABLE禁用作业。

    您可以通过DBMS_SCHEDULER的ENABLE禁用作业。

    创建的任务中会涉及使用日历表示法进行时间定义,日历表示法是用来定义重复计划的实现方法,能实现一些复杂的时间计划。

    您可以通过DBMS_SCHEDULER的EVALUATE_CALENDAR_STRING计算符合规则的下一次计划运行时间。

    另请参阅:

    有关DBMS_SCHEDULER的详细信息,请参见KingbaseES扩展插件参考手册中kbd_schedule模块;

    18.1. 作业调度及其子程序

    您可以使用DBMS_SCHEDULER包中的子程序来管理常见任务和调度计划。

    下图展示了常见任务及其DBMS_SCHEDULER子程序:

    表 18.1.1 DBMS_SCHEDULER软件包子程序

    子程序

    描述

    CREATE_PROGRAM Procedure

    创建一个程序

    DROP_PROGRAM Procedure

    删除一个程序

    CREATE_SCHEDULER Procedure

    创建一个调度计划

    DROP_SCHEDULE Procedure

    删除一个调度计划

    EVALUTE_CALENDAR_STRING Procedure

    计算符合规则的下一个日期

    CREATE_JOB Procedure

    创建一个作业

    DROP_JOB Procedure

    删除一个作业

    RUN_JOB Procedure

    运行一个作业

    DISABLE Procedure

    将一个作业状态设置为DISABLE

    ENABLE Procedure

    将一个作业状态设置为ENABLE

    DBMS_SCHEDULER具有如下限制:

    1. 需要创建kdb_schedule扩展。

    2. 间隔时间采用日历表示法。

    3. 使用该功能需要必要的GUC参数。

    父主题: 数据库作业调度

    18.2. 创建程序

    创建程序为了告诉调度器要运行什么。

    默认情况下,程序在创建者的模式中创建。要在另一个用户的模式中创建程序,必须使用模式名称对程序名进行限定。要让其他用户使用您的程序,他们必须具有执行权限,因此一旦创建了程序,您必须授予该程序执行权限。

    下面的例子创建一个计划任务的程序,名字为program1,程序的类型为PLSQL_BLOCK,程序执行创建表t2。

    call DBMS_SCHEDULER.CREATE_PROGRAM('program1', 'PLSQL_BLOCK', 'create table t2(A int)','user=system dbname=test port=54321 password=123456', 'test', 0, true, 'this is test program');
    

    创建后您可以禁用或者启用该任务,后面将描述该内容。

    18.3. 删除程序

    您可以通过DBMS_SCHEDULER的DROP_PROGRAM删除一个或多个程序。

    当程序被删除时,与之相关的任何参数都会被删除,如下示例,可以在一次调用中通过逗号删除多个程序,也可以只删除一个程序。

    call DBMS_SCHEDULER.DROP_PROGRAM('program1');
    

    父主题: 数据库作业调度

    18.4. 创建调度计划

    您可以通过DBMS_SCHEDULER的CREATE_SCHEDULER创建调度计划。

    调度计划是在创建该任务时的用户模式下创建的,并且第一次创建时即启动。您可以在其他用户模式下创建计划任务,一旦被创建,它就可以被其他用户使用。

    下列示例创建一个名为schedule1的计划任务,规划在每天的早上10点10分10秒时。

    call DBMS_SCHEDULER.CREATE_SCHEDULE('schedule1', now(), 'FREQ=MINUTELY;BYSECOND=10', NULL, 'this is test schedule');
    

    父主题: 数据库作业调度

    18.5. 删除调度计划

    您可以通过DBMS_SCHEDULER的DROP_SCHEDULE删除调度计划。

    call DBMS_SCHEDULER.DROP_SCHEDULE('schedule1');
    

    父主题: 数据库作业调度

    18.6. 创建作业

    当您完成了程序和调度计划的创建,意味着可以基于两者创建一个有计划的作业(job)。

    如下示例,schedule1定义了调度计划,program1定义了要执行的什么内容(程序),创建的作业将两者“组合”形成一个有调度计划的作业。

    call DBMS_SCHEDULER.CREATE_JOB('job1', 'program1', 'schedule1', 'Routine Maintenance', true, true, 'this is test job');
    

    父主题: 数据库作业调度

    18.7. 删除作业

    当我们不再需要作业时,可以使用DROP_JOB删除一个指定的作业。

    如下示例,删除了一个名为job1的作业。

    call DBMS_SCHEDULER.DROP_JOB('job1', false, false, 'STOP_ON_FIRST_ERROR');
    

    父主题: 数据库作业调度

    18.8. 运行作业

    通过调用DBMS_SCHEDULER.RUN_JOB,您可以使用RUN_JOB程序来测试作业或者在调度计划之外运行它。

    RUN_JOB的use_current_session确定的是作业时异步还是同步,默认为true,目前暂时不支持。

    下列示例展示了,运行一个名为job1的任务。

    call DBMS_SCHEDULER.RUN_JOB('job1', true);
    

    父主题: 数据库作业调度

    18.9. 禁用作业

    您可以通过DBMS_SCHEDULER的DISABLE禁用作业。

    作业也可以通过其他方式失去功能效果,比如,删除作业指向的程序或者调度计划将形成失去功能,调度器尝试运行时将会报错。禁用作业意味着,尽管作业的元数据存在,但作业调度器不会对其进行处理。当作业被禁用时,作业在作业表中的状态为已禁用。

    当一个正在运行的作业被禁用时,并且force(第二个参数)为false(默认值),将返回一个错误。目前force暂不支持true。如果commit_semantics被设置为STOP_ON_FIRST_ERROR(默认值),将在出现第一个错误时返回调用。(该参数暂不支持其他设置)

    下列示例展示了禁用一个作业。

    call DBMS_SCHEDULER.DISABLE('job1', false, 'STOP_ON_FIRST_ERROR');
    

    父主题: 数据库作业调度

    18.10. 启用作业

    您可以通过DBMS_SCHEDULER包的ENABLE启用作业。

    该子程序的作用是,禁用状态的作业被调度器重新捡起来进行处理,默认情况下,创建的作业时禁用状态的,因此需要启用它们才能正常工作。当作业启动时,将执行有效性检查,如果检查不通过将不会启动作业。

    启用作业后会立刻根据调度计划运行作业。如果commit_semantics被设置为STOP_ON_FIRST_ERROR(默认值),将在出现第一个错误时返回调用。

    下列示例展示了启用一个名为job1的计划任务。

    call DBMS_SCHEDULER.ENABLE('job1', 'STOP_ON_FIRST_ERROR');
    

    父主题: 数据库作业调度

    18.11. 任务的日历表示法

    创建的任务中会涉及使用日历表示法进行时间定义,日历表示法是用来定义重复计划的实现方法,能实现一些复杂的时间计划。

    下列是一些可行的日历表示法示例:

    示例:

    每天早上10点

    FREQ=DAILY;BYHOUR=10;BYMINUTE=0;BYSECOND=0;
    

    每隔7天的早上10点

    FREQ=DAILY;INTERVAL=7;BYHOUR=10;BYMINUTE=0;BYSECOND=0;
    

    每年10月1号早上10点

    FREQ=YEARLY;BYMONTH=10;BYMONTHDAY=1;BYHOUR=10;BYMINUTE=0;BYSECOND=0;
    

    父主题: 数据库作业调度

    18.12. 计算符合规则的下一个日期

    您可以通过DBMS_SCHEDULER的EVALUATE_CALENDAR_STRING计算符合规则的下一次计划运行时间。计算结果保存在参数next_run_date中。

    下列例子展示了,计算'freq=yearly;interval=5;bymonth=10;bymonthday=10;byhour=10;byminute=10;bysecond=10'这个较复杂的日历规则下一次的计划运行时间,并将其打印显示出来。

    示例:

    declare
    next_run_date timestamp;
    begin DBMS_SCHEDULER.EVALUATE_CALENDAR_STRING('freq=yearly;interval=5;bymonth=10;
    bymonthday=10;byhour=10;byminute=10;bysecond=10','','',next_run_date);
    DBMS_OUTPUT.PUT_LINE(next_run_date);
    end;
    

    父主题: 

    数据库作业调度

  • 相关阅读:
    Github 爆火,程序员疯抢的 Java 面试宝典(PDF 版)限时开源
    多目标跟踪匈牙利 - 卡尔曼滤波算法
    热噪声 Thermal noise
    【Linux】关于进程的理解、状态、优先级和进程切换
    计算机网络实验 第四次 11月1日
    2023京东口腔护理赛道行业数据分析(京东销售数据分析)
    【shell】linux通过complete命令完成使用tab键自动补全
    Dinky,让 Flink SQL 纵享丝滑
    SUSE zypper 添加源和离线下载rpm包
    IMU用于飞行坐姿校正
  • 原文地址:https://blog.csdn.net/arthemis_14/article/details/125890743