广告
返回顶部
首页 > 资讯 > 数据库 >Oracle Job Chain
  • 519
分享到

Oracle Job Chain

2024-04-02 19:04:59 519人浏览 八月长安
摘要

Job Chains创建chain的顺序创建chain object;定义chain中的steps;增加规则;启用chain;创建指向这个chain的job。创建Chain Object实验描述:ENV:c

Job Chains

创建chain的顺序

  1. 创建chain object;

  2. 定义chain中的steps;

  3. 增加规则;

  4. 启用chain;

  5. 创建指向这个chain的job。

创建Chain Object

实验描述:

ENV:create table test_chain(id number);

createtable test_chain1(id number);

createtable test_chain2(id number);

step1:test_chain1表插入一条数据;

step2:step1执行成功后,test_chain中有超过两条数据时,插入test_chain2表一条数据。

begin

dbms_scheduler.create_chain(chain_name=>'my_chain1',rule_set_name=>null,evaluation_interval=>interval '1' minute,

comments=>'Chain with 30 minuteevaluation interval');

end;

/

PL/sql procedure successfully completed.

evaluation_interval指的是chain rule的扫描间隔,这里是自定义的。Scheduler在启动job chain时和每次执行完chain step时都会去扫描chain rule,这里除了启动job chain时和chain step结束时,还会每一分钟自动扫描一次来判断rule的正确性。这个参数对于某种特殊情形,本次实验就启用这个参数。

定义Chain Steps

创建program

begin

dbms_scheduler.create_program(program_name=>'my_program1',program_type=>'PLSQL_BLOCK',

program_action=>'begin insert intotest_chain1 values (1);commit;end;');

end;

/

 

PL/SQL procedure successfully completed.

begin

dbms_scheduler.create_program(program_name=>'my_program2',program_type=>'PLSQL_BLOCK',

program_action=>'begin insert intotest_chain2 values (2);commit;end;');

end;

/

 

PL/SQL procedure successfully completed.

--enable program

SQL> begin 

 2 dbms_scheduler.enable('my_program1,my_program2');

 3  end;

 4  /

创建step

begin

dbms_scheduler.define_chain_step(chain_name=>'my_chain1',step_name=>'my_step1',program_name=>'my_program1');

dbms_scheduler.define_chain_step(chain_name=>'my_chain1',step_name=>'my_step2',program_name=>'my_program2');

end;

/

 

PL/SQL procedure successfully completed.

Note:定义step时,program和chain可以不存在,但是启动chain时,必须保证program

和chain存在。

增加Chain规则

Rule描述:

step1直接执行;

step2执行条件:step1执行成功,并且(selectcount(*) from test_chain) >=2

begin                               

dbms_scheduler.define_chain_rule(chain_name=>'my_chain1',condition=>'TRUE',action=>'startmy_step1',rule_name=>'rule_1');

end;

/

 

PL/SQL procedure successfully completed.

 

begin

dbms_scheduler.define_chain_rule(chain_name=>'my_chain1',condition=>':my_step1.state=''SUCCEEDED''and (select count(*) from test_chain) >=2',

action=>'startmy_step2',rule_name=>'rule_1_2');

end;

/

 

PL/SQL procedure successfully completed.

启用Chain

begin

dbms_scheduler.enable('my_chain1');

end;

/

 

PL/SQL procedure successfully completed.

创建Chain job

Note:直接调用run_chain运行则不需enablechain,创建job则需要。

begin

dbms_scheduler.create_job(job_name=>'chain_job_1',job_type=>'CHAIN',job_action=>'my_chain1',

start_date=>sysdate,repeat_interval=>'freq=minutely;interval=1',enabled=>TRUE);

end;

/

Note:单独启动job,注意参数USE_CURRENT_SESSION=>false

SQL> begin

 2 dbms_scheduler.run_job(job_name=>'chain_job_1',USE_CURRENT_SESSION=>false);

 3  end;

 4  /

 

SQL> selectjob_name,job_subname,status,req_start_date,actual_start_date fromuser_scheduler_job_run_details where job_name='CHAIN_JOB_1';

 

JOB_NAME        JOB_SUBNAME          STATUS     REQ_START_DATE                                     ACTUAL_START_DATE

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

CHAIN_JOB_1                          STOPPED    16-JUN-16 03.44.03.000000 PM +08:00                16-JUN-16 03.44.03.588735 PM+08:00

CHAIN_JOB_1     MY_STEP1             FAILED     16-JUN-16 03.44.03.682508 PM +08:00                16-JUN-16 03.44.03.693946 PM+08:00

CHAIN_JOB_1     MY_STEP1             SUCCEEDED  16-JUN-16 04.17.43.335679 PM +08:00                16-JUN-16 04.17.43.436069 PM+08:00

发现my_step2还没有运行

SQL> select * from test_chain1;

 

       ID

----------

        1

my_program1已写入数据

制造my_step2启动的条件

SQL> insert into test_chainvalues(9);

 

1 row created.

 

SQL> /

 

1 row created.

SQL> commit;

 

Commit complete.

SQL> selectjob_name,job_subname,status,req_start_date,actual_start_date fromuser_scheduler_job_run_details where job_name='CHAIN_JOB_1';

 

JOB_NAME        JOB_SUBNAME          STATUS     REQ_START_DATE                                     ACTUAL_START_DATE

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

CHAIN_JOB_1                          STOPPED    16-JUN-16 03.44.03.000000 PM +08:00                16-JUN-16 03.44.03.588735 PM+08:00

CHAIN_JOB_1     MY_STEP2             SUCCEEDED  16-JUN-16 04.30.43.064558 PM +08:00                16-JUN-16 04.30.43.152496 PM+08:00

CHAIN_JOB_1     MY_STEP1             FAILED     16-JUN-16 03.44.03.682508 PM +08:00                16-JUN-16 03.44.03.693946 PM+08:00

CHAIN_JOB_1     MY_STEP1             SUCCEEDED  16-JUN-16 04.17.43.335679 PM +08:00                16-JUN-16 04.17.43.436069 PM+08:00

SQL> select * from test_chain2;

 

       ID

----------

        2


您可能感兴趣的文档:

--结束END--

本文标题: Oracle Job Chain

本文链接: https://www.lsjlt.com/news/41926.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Oracle Job Chain
    Job Chains创建chain的顺序创建chain object;定义chain中的steps;增加规则;启用chain;创建指向这个chain的job。创建Chain Object实验描述:ENV:c...
    99+
    2022-10-18
  • ORA-27435: chain job terminated abnormally ORACLE 报错 故障修复 远程处理
    文档解释 ORA-27435: chain job terminated abnormally Cause: A chain job has ended abnormally. The error code for the running ...
    99+
    2023-11-05
    报错 故障 chain
  • ORA-27434: cannot alter chain step job string.string.string ORACLE 报错 故障修复 远程处理
    文档解释 ORA-27434: cannot alter chain step job string.string.string Cause: A step job of a running chain cannot be altered,...
    99+
    2023-11-05
    报错 故障 alter
  • oracle JOB
    每天1点执行的oracle JOB样例DECLAREX NUMBER;BEGINSYS.DBMS_JOB.SUBMIT( job => X,what => 'ETL_RUN_D_Date;'...
    99+
    2022-10-18
  • oracle中的job
    oracle知识点-joboracle中的job类似于Linux中的crontab的作用,用于定时执行某些操作相关视图:dba_jobs,user_jobs,all_jobs,dba_jobs_runnin...
    99+
    2022-10-18
  • oracle job的迁移
    因为JOB的内容是写死的,如果使用remap导入到别的用户下,其log_user等还是原来的,再加上job的id是固定的,很可能和当前库有冲突,所以建议取出job的ddl。 dbms_metada...
    99+
    2022-10-18
  • oracle的定时器job
    1、创建一个存储过程my_proc();2、创建一个定时器,这是这个JOB在创建的时候已经被运行;declare test_job number;begin    s...
    99+
    2022-10-18
  • oracle job一直运行
    用oracle的job定时调用存储过程,如存储过程陷入死循环或其他原因导致,job的状态是一直运行。这时,手动调用存储过程,由于锁表的原因,存储过程也会执行不下去。此时,需要先停掉job,命令如下:BEGI...
    99+
    2022-10-18
  • oracle 中怎么创建JOB
    今天就跟大家聊聊有关oracle 中怎么创建JOB,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1、创建JOB,可以指定固定的时间(对运行时间的管理...
    99+
    2022-10-18
  • Oracle数据库定时器Job
    写法: declare jobno number; begin dbms_job.submit( jobno, 'nextMonthInventoryCARRYFORWAR...
    99+
    2022-10-18
  • oracle job 定时执行参数
    oracle job 常见的执行时间1、每分钟执行trunc(sysdate,'mi')+1/(24*60)2、每天定时执行如:每天凌晨0点执行trunc(sysdate+1)每天凌晨1点执行trunc(s...
    99+
    2022-10-18
  • ORA-23421: job number string is not a job in the job queue ORACLE 报错 故障修复 远程处理
    文档解释 ORA-23421: job number string is not a job in the job queue Cause: There is no job visible to the caller with the gi...
    99+
    2023-11-05
    报错 故障 job
  • pb怎么调用oracle中的job
    要在Oracle中调用一个job,你可以使用Oracle的DBMS_SCHEDULER包来实现。下面是一些示例代码来展示如何调用一个...
    99+
    2023-10-28
    PB oracle
  • Oracle job自动任务实用指南
    作为oracle的定时任务,oracle job介于服务器层级的crontab和应用程序(如java spring的定时任务)之间,在数据库层对数据处理有重要的价值。下面简单分享一下oracle job如何...
    99+
    2022-10-18
  • Oracle job定时任务怎么理解
    这篇文章主要介绍“Oracle job定时任务怎么理解”,在日常操作中,相信很多人在Oracle job定时任务怎么理解问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Orac...
    99+
    2022-10-19
  • ORA-32317: cannot run a job from a job ORACLE 报错 故障修复 远程处理
    文档解释 ORA-32317: cannot run a job from a job Cause: An attempt was made to execute a job from within another job. Action:...
    99+
    2023-11-05
    报错 故障 ORA
  • 如何在SQL Server和Oracle中创建job
    这篇文章主要讲解了“如何在SQL Server和Oracle中创建job”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何在SQL Server和Oracl...
    99+
    2022-10-18
  • Oracle数据库JOB失败怎么解决
    今天小编给大家分享一下Oracle数据库JOB失败怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起...
    99+
    2022-10-19
  • Oracle调度Schedule特性(第一部分)-job
    在主机层面,我想要执行一些定时任务,通常会使用crontab。方便又实用,那么oracle里面是不是也有定时任务的概念呢? Oracle Scheduler的引入就是用来管理和计划数据库的Job,通过它可以...
    99+
    2022-10-18
  • Oracle 11g 测试停库对job的影响
    环境: OS:Centos 7.5 DB:Oracle 11.2.0.4.0单实例 场景一:job没开始,停库, 再次起库后,起库时间为job开始时间,开始自动运行job,不会自动...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作