(9)使用Chains之创建CHAIN

五、使用Chains

今天要来认识一位新同学:CHAIN(注意不要敲成CHINA)。CHAIN可以被视做一组Programs的复合,举个简单的例子:运行PROGRAM:A以及PROGRAM:B,如果成功的话继续运行PROGRAM:C,否则的话运行PROGRAM:D。Programs:A、B、C、D以及执行的逻辑关系就构成了一个最简单的CHAIN。

关于CHAIN的管理操作比较多,比如创建/删除/修改Chains,添加/修改/删除Chain Steps等等。

5.1  创建Chains

5.1.1  创建CHAIN对象

创建CHAIN使用DBMS_SCHEDULER.CREATE_CHAIN过程,这个过程调用非常简单,因为需要指定的参数极少,该过程的定义如下:

SQL> desc dbms_scheduler.create_chain;

Parameter           Type                   Mode Default?

------------------- ---------------------- ---- --------

CHAIN_NAME          VARCHAR2               IN

RULE_SET_NAME       VARCHAR2               IN   Y

EVALUATION_INTERVAL INTERVAL DAY TO SECOND IN   YCOMMENTS            VARCHAR2               IN   Y

在创建时,甚至可以简单到只指定一个CHAIN的名称,其它均为空即可,例如:

SQL> exec dbms_scheduler.create_chain(¨my_chain1¨);PL/SQL procedure successfully completed.

定义好的Chains,可以通过*_SCHEDULER_CHAINS视图查看,例如:

SQL> select chain_name from user_scheduler_chains;

CHAIN_NAME

------------------------------MY_CHAIN1

注意,不是说创建了CHAIN就齐活,只有一个CHAIN对象ORACLE还是啥也干不了(当然啦,相信从上面执行的创建语句大家也看出来了),CHAIN对象创建之后,要做的工作其实才刚刚开始。其后,还需要定义Chain Steps以及Chain rules。

5.1.2  创建Chain Step

Chain Steps 就是用来指定CHAIN执行的操作及执行步骤,创建CHAIN STEP是通过DBMS_SCHEDULER.DEFINE_CHAIN_STEP过程进行,例如,为刚刚创建的my_chain1添加一个step,执行操作如下:

SQL> begin

2  DBMS_SCHEDULER.DEFINE_CHAIN_STEP (

3     chain_name      =>  ¨my_chain1¨,

4     step_name       =>  ¨my_step1¨,

5     program_name    =>  ¨p_p1¨);

6  end;

7  /PL/SQL procedure successfully completed.

Chain Steps 即可以调用PROGRAM(注意是program,不是procedure,当然program中可以定义执行procedure),也可以调用EVENT,甚至调用其它CHAIN(这就叫嵌套CHAIN)。

下面接着为my_chain1添加两个step,操作如下:

SQL> begin

2  DBMS_SCHEDULER.DEFINE_CHAIN_STEP (

3     chain_name      =>  ¨my_chain1¨,

4     step_name       =>  ¨my_step2¨,

5     program_name    =>  ¨p_p2¨);

6  DBMS_SCHEDULER.DEFINE_CHAIN_STEP (

7     chain_name      =>  ¨my_chain1¨,

8     step_name       =>  ¨my_step3¨,

9     program_name    =>  ¨p_p3¨);

10  end;

11  /PL/SQL procedure successfully completed.

要查询定义的Chain Steps,则是通过*_SCHEDULER_CHAIN_STEPS视图,例如:

SQL> select chain_name,step_name,program_name from user_scheduler_chain_steps;

CHAIN_NAME           STEP_NAME            PROGRAM_NAME

-------------------- -------------------- --------------------

MY_CHAIN1            MY_STEP1             P_P1

MY_CHAIN1            MY_STEP2             P_P2MY_CHAIN1            MY_STEP3             P_P3

5.1.3  创建Chain Rule

接下来,要为CHAIN的运行定义规则。定义规则是使用DBMS_SCHEDULER.DEFINE_CHAIN_RULE过程,Chain Rules依赖于Chain Steps,每个CHAIN RULE都拥有condition和action属性,当满足condition时则执行action中指定的step。

DBMS_SCHEDULER.DEFINE_CHAIN_RULE 过程的语法如下:

SQL> desc dbms_scheduler.define_chain_rule;

Parameter  Type     Mode Default?

---------- -------- ---- --------

CHAIN_NAME VARCHAR2 IN

CONDITION  VARCHAR2 IN

ACTION     VARCHAR2 IN

RULE_NAME  VARCHAR2 IN   YCOMMENTS   VARCHAR2 IN   Y

CHAIN_NAME 就不说了,需要注意的是CONDITION和ACTION两个参数。在为condition参数指定值时,其语法看起来稍稍复杂一些,或者说是灵活,condition参数值支持下列的语法形式:

TRUE

FALSE

stepname [NOT] SUCCEEDED

stepname [NOT] FAILED

stepname [NOT] STOPPED

stepname [NOT] COMPLETED

stepname ERROR_CODE IN (integer, integer, integer ...)

stepname ERROR_CODE NOT IN (integer, integer, integer ...)

stepname ERROR_CODE = integer

stepname ERROR_CODE != integer

stepname ERROR_CODE <> integer

stepname ERROR_CODE > integer

stepname ERROR_CODE >= integer

stepname ERROR_CODE

stepname ERROR_CODE <= integer

甚至于,还可以制定成下列逻辑语法:

expression AND expression

expression OR expression

NOT (expression)

比如说,我们希望条件为step1成功运行,那么可以指定condition参数值如下:

¨step1 completed¨

Action 参数相对简单一些,这个参数用来指定当满足condition参数时,CHAIN执行的操作。

例如,创建CHAIN RULE,首先执行my_step1,如果my_step1成功执行的话,就继续执行my_step2,如果my_step2也成功执行的话,则结束该CHAIN,创建脚本如下:

SQL> BEGIN

2  DBMS_SCHEDULER.DEFINE_CHAIN_RULE (

3     chain_name   =>   ¨my_chain1¨,

4     condition    =>   ¨TRUE¨,

5     action       =>   ¨START my_step1¨,

6     rule_name    =>   ¨my_rule1¨);

7  DBMS_SCHEDULER.DEFINE_CHAIN_RULE (

8     chain_name   =>   ¨my_chain1¨,

9     condition    =>   ¨my_step1 completed¨,

10     action       =>   ¨START my_step2¨,

11     rule_name    =>   ¨my_rule2¨);

12  DBMS_SCHEDULER.DEFINE_CHAIN_RULE (

13     chain_name   =>   ¨my_chain1¨,

14     condition    =>   ¨my_step2 completed¨,

15     action       =>   ¨end 0¨,

16     rule_name    =>   ¨my_rule3¨);

17  END;

18  /PL/SQL procedure successfully completed.

5.1.4  运行Chains

最后,来运行一下创建的my_chain1吧,手动运行CHAIN是通过DBMS_SCHEDULER.RUN_CHAIN过程,例如:

SQL> BEGIN

2  DBMS_SCHEDULER.RUN_CHAIN (

3     chain_name    =>  ¨my_chain1¨,

4     start_steps   =>  ¨my_step1¨);

5  END;

6  /PL/SQL procedure successfully completed.

语句执行成功,下面需要查看一下执行的结果。我们之前定义的p_p1等program对象,实际上是调用procedure,向一个指定表jss_t2中插入记录,这里直接查询一下该表,就知道执行情况了(在此之前,jss_t2表为空):

SQL> select * from jss_t2;

TP                             DT

------------------------------ ------------

p_p1 inserted                  03-SEP-09p_p2 inserted                  03-SEP-09

你看,jss_t2表中有了两条记录,对应前面设置的CHAIN RULE,说明my_step1和my_step2均已正确执行。

提示:Chains在执行前,必须被置于enabled状态,默认情况下刚刚创建的CHAIN都是disabled状态,要修改Chains的状态,还是通过DBMS_SCHEDULER.ENABLE和DBMS_SCHEDULER.DISABLE两过程,这里就不演示了。

手动执行的CHAIN的话没有系统级的日志记录,因此如果希望看到详细执行情况的话,建议创建job来执行CHAIN,例如:

SQL> BEGIN

2  DBMS_SCHEDULER.CREATE_JOB (

3     job_name        => ¨chain_job_1¨,

4     job_type        => ¨CHAIN¨,

5     job_action      => ¨my_chain1¨,

6     repeat_interval => ¨freq=daily;interval=1¨,

7     enabled         => TRUE);

8  END;

9  /PL/SQL procedure successfully completed.

然后,dba就可以通过定期观察*_scheduler_job_run_details视图来确认chain的执行情况了。

全面学习ORACLE Scheduler特性系列:

oracle job执行chain,全面学习ORACLE Scheduler特性(9)使用Chains之创建CHAIN相关推荐

  1. java oracle 分区查询_深入学习Oracle分区表及分区索引

    深入学习Oracle分区表及分区索引 关于分区表和分区索引(About Partitioned Tables and Indexes)对于10gR2而言,基本上可以分成几类: •       Rang ...

  2. oracle列名无效字符,案例学习Oracle错误:ORA-00904 invalid column name

    ORA-00904 invalid column name ORA-00904: 无效的列名 Cause The column name entered is either missing or in ...

  3. oracle exp执行失败,EXP-00056: 遇到 ORACLE 错误 25153

    执行导出方案时报错: EXP-00056: 遇到 ORACLE 错误 25153 ORA-25153: 临时表空间为空 EXP-00000: 导出终止失败 操作如下 M:\oracle\product ...

  4. oracle查看执行过的语句,oracle 查询执行过的SQL语句

    MySQL开启日志记录查询/执行过的SQL语句 作为后端开发者,遇到数据库问题的时候应该通过分析SQL语句来跟进问题所在,该方法可以记录所有的查询/执行的SQL语句到日志文件. 方法有几种,但是个人觉 ...

  5. Oracle数据库中的方案,学习Oracle数据库_理解Oracle数据库中的方案

    理解数据库.表空间.数据文件之间的关系. 每个表空间由一个或多个数据文件组成.数据文件用于在物理上存储表空间中所有逻辑结构的数据.表空间中数据文件的大小之和就是表空间的存储容量(图中系统表空间存储容量 ...

  6. oracle中执行自带脚本,oracle自带脚本

    ------------------------------------------------------------优化相关------------------------------------ ...

  7. oracle sqlplus执行脚本_连接Oracle出错:sqlplus quot;/as sysdbaquot;

    执行sqlplus "/as sysdba" 出现错误:sqlplus: error while loading shared libraries: /u01/app/oracle ...

  8. 怎么在oracle里执行sql语句,在Oracle中执行动态SQL的几种方法

    在一般的sql操作中,sql语句基本上都是固定的,如: SELECT t.empno,t.ename FROM scott.emp t WHERE t.deptno = 20; 但有的时候,从应用的需 ...

  9. oracle中执行字符串sql语句,Oracle SQL 字符串操作

    这些函数全都接收的是字符族类型的参数(CHR除外)并且返回字符值. 除了特别说明的之外,这些函数大部分返回VARCHAR2类型的数值. 字符函数的返回类型所受的限制和基本数据库类型所受的限制是相同的. ...

最新文章

  1. 基于visual Studio2013解决面试题之0209最大堆排序
  2. System Analysic utility tools
  3. (LeetCode 141/142)Linked List Cycle
  4. 视音频数据处理入门:PCM音频采样数据处理
  5. IE11浏览器一个窗口打开多个页面设置方法
  6. cad无法加载arx文件_CAD文件损坏?无法打开?试试这8个方法吧
  7. 回顾2018,展望2019
  8. php文章上一篇,thinkphp5实现文章上一篇,下一篇
  9. Django中的templates(你的HTML页面放哪里)
  10. 关于matlab中数据拟合的一些函数polyfit()
  11. python音乐播放器代码_Python简易音乐播放器
  12. 18款表白源码,搭建网站必备,总有一款适合你
  13. 为什么现在android UI设计能火起来?
  14. 【多线程】线程池的创建和参数设定
  15. dataGridView 粘贴数据并更新到数据库及发送邮件(二)
  16. 金链盟中国区块链应用大赛正式启动,200万奖金花落谁家?
  17. v7.widget.SearchView的使用
  18. flex vue 垂直居中居上_CSS3 Flex实现元素的水平居中和垂直居中
  19. Python - zip和izip函数 以及 位置参数和命名参数的运用
  20. 通过了华为认证可以涨薪吗?

热门文章

  1. C Primer Plus 第12章 12.6 分配内存:malloc()和free()
  2. 临时购物车用户购物车
  3. 记录数据 生活管家APP
  4. 大数据治理的核心是什么
  5. linux下生成nginx证书 【超简洁步骤】
  6. 钽电容、铝电解、陶瓷电容作为DCDC输出电容的比较
  7. 上海市浦东新区37街镇最新版行政区域
  8. 【华人学者风采】俞勇 上海交通大学
  9. 疫情当下无法继续学画画?来美术集线上画室在家好好学美术~
  10. 微信小程序页面自动跳转外链