[oracle@tyger dbs]$ sqlplus / as sysdba





SQL*Plus: Release 10.2.0.1.0 - Production on Tue May 6 13:02:41 2014





Copyright (c) 1982, 2005, Oracle.  All rights reserved.









Connected to:

Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production

With the Partitioning, OLAP and Data Mining options





/* 创建測试用户tyger 赋予权限 */





SYS@ORCL>drop user tyger cascade;





User dropped.





SYS@ORCL>create user tyger identified by tyger account unlock;





User created.





SYS@ORCL>grant connect,resource to tyger;





Grant succeeded.





SYS@ORCL>conn tyger/tyger

Connected.





/* 创建序列 seq_chain 以及測试表 tab1  tab2  tab3 */





TYGER@ORCL>create sequence seq_chain;





Sequence created.





TYGER@ORCL>create table tab1(id number(5),cdate date,sdate date default sysdate);





Table created.





TYGER@ORCL>create table tab2(id number(5),cdate date,sdate date default sysdate);





Table created.





TYGER@ORCL>create table tab3(id number(5),cdate date,sdate date default sysdate);





Table created.





/* 创建program 报错权限不足  */





TYGER@ORCL>begin

DBMS_SCHEDULER.CREATE_PROGRAM (

   program_name             => 'CHAIN_P1',

   program_type             => 'PLSQL_BLOCK',

   program_action           => 'begin

        execute immediate ''insert into tab1(id,cdate)

                values(seq_chain.nextval,add_months(sysdate,seq_chain.currval))'';

        end;',

   enabled                  => true);

end;

/

  2    3    4    5    6    7    8    9   10   11  

*

ERROR at line 1:

ORA-27486: insufficient privileges

ORA-06512: at "SYS.DBMS_ISCHED", line 5

ORA-06512: at "SYS.DBMS_SCHEDULER", line 30

ORA-06512: at line 2

 /* 赋予必要权限 以及接下去实验须要的权限 */



TYGER@ORCL>conn / as sysdba

Connected.

SYS@ORCL>grant create job to tyger;





Grant succeeded.





SYS@ORCL>grant create evaluation context to tyger;





Grant succeeded.





SYS@ORCL>grant create rule set to tyger;





Grant succeeded.





SYS@ORCL>grant create rule to tyger;





Grant succeeded.

/* 创建program  */

SYS@ORCL>conn tyger/tyger

Connected.



TYGER@ORCL>begin

DBMS_SCHEDULER.CREATE_PROGRAM (

   program_name             => 'CHAIN_P1',

   program_type             => 'PLSQL_BLOCK',

   program_action           => 'begin

        execute immediate ''insert into tab1(id,cdate)

                values(seq_chain.nextval,add_months(sysdate,seq_chain.currval))'';

        end;',

   enabled                  => true);

end;

/

  2    3    4    5    6    7    8    9   10   11  

PL/SQL procedure successfully completed.





TYGER@ORCL>begin

DBMS_SCHEDULER.CREATE_PROGRAM (

   program_name             => 'chain_step2',

   program_type             => 'PLSQL_BLOCK',

   program_action           => 'begin

        execute immediate ''insert into tab2(id,cdate)

                values(seq_chain.nextval,add_months(sysdate,seq_chain.currval))'';

        end;',

   enabled                  => true);

end;

/

  2    3    4    5    6    7    8    9   10   11  

PL/SQL procedure successfully completed.





TYGER@ORCL>begin

DBMS_SCHEDULER.CREATE_PROGRAM (

   program_name             => 'CHAIN_P3',

   program_type             => 'PLSQL_BLOCK',

   program_action           => 'begin

        execute immediate ''insert into tab3(id,cdate)

                values(seq_chain.nextval,add_months(sysdate,seq_chain.currval))'';

        end;',

   enabled                  => true);

end;

/

  2    3    4    5    6    7    8    9   10   11  

PL/SQL procedure successfully completed.









/* 创建链tyger_chain */





TYGER@ORCL>exec dbms_scheduler.create_chain('tyger_chain');





PL/SQL procedure successfully completed.





TYGER@ORCL>select chain_name from user_scheduler_chains;





CHAIN_NAME

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

TYGER_CHAIN









/* 创建chain step 

为链TYGER_CHAIN 加入step ,能够一个一个的加入,也能够一下所有加入 */



TYGER@ORCL>

TYGER@ORCL>begin 

dbms_scheduler.define_chain_step(

   chain_name =>'TYGER_CHAIN',

   step_name =>'CHAIN_STEP1',

   program_name => 'CHAIN_P1');

end;

/

  2    3    4    5    6    7  

PL/SQL procedure successfully completed.





TYGER@ORCL>begin

 dbms_scheduler.define_chain_step(

    chain_name =>'TYGER_CHAIN',

     step_name =>'CHAIN_STEP2',

     program_name => 'chain_step2');

 dbms_scheduler.define_chain_step(

    chain_name =>'TYGER_CHAIN',

     step_name =>'chain_step3',

    program_name => 'CHAIN_P3');

 end;

 /

  2    3    4    5    6    7    8    9   10   11  

PL/SQL procedure successfully completed.





/* 查看创建的step 是否成功 */





TYGER@ORCL>col chain_name for a16

TYGER@ORCL>col step_name for a16

TYGER@ORCL>col program_name for a16

TYGER@ORCL>select chain_name,step_name,program_name  

  2  from user_scheduler_chain_steps;





CHAIN_NAME       STEP_NAME        PROGRAM_NAME

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

TYGER_CHAIN CHAIN_STEP1 CHAIN_P1

TYGER_CHAIN CHAIN_STEP2 CHAIN_P2

TYGER_CHAIN CHAIN_STEP3 CHAIN_P3









/* 为链创建规则 */



/* 规则:首先运行 chain_step1,成功完毕后运行 chain_step2 ,成功完毕后运行 chain_step3,成功完毕后,结束。 */



TYGER@ORCL>

TYGER@ORCL>begin

DBMS_SCHEDULER.DEFINE_CHAIN_RULE (

   chain_name              => 'TYGER_CHAIN',

   condition               => 'true',

   action                  => 'start CHAIN_STEP1',

   rule_name               => 'rule_01');

DBMS_SCHEDULER.DEFINE_CHAIN_RULE (

   chain_name              => 'TYGER_CHAIN',

   condition               => 'CHAIN_STEP1 SUCCEEDED',

   action                  => 'start chain_step2',

   rule_name               => 'rule_02');

DBMS_SCHEDULER.DEFINE_CHAIN_RULE (

   chain_name              => 'TYGER_CHAIN',

   condition               => 'chain_step2 SUCCEEDED',

   action                  => 'start chain_step3',

   rule_name               => 'rule_03');

DBMS_SCHEDULER.DEFINE_CHAIN_RULE (

   chain_name              => 'TYGER_CHAIN',

   condition               => 'chain_step3 SUCCEEDED',

   action                  => 'END 0',

   rule_name               => 'rule_04');

END;

/

  2    3    4    5    6    7    8    9   10   11   12   13   14   15   16   17   18   19   20   21   22   23  

PL/SQL procedure successfully completed.





/* 启用链 tyger_chain */





TYGER@ORCL>exec dbms_scheduler.enable('TYGER_CHAIN');





PL/SQL procedure successfully completed.

手动执行链 tyger_chain

TYGER@ORCL>begin

DBMS_SCHEDULER.RUN_CHAIN (

   chain_name               =>'TYGER_CHAIN',

   start_steps              =>'CHAIN_STEP1');

end;

/

  2    3    4    5    6  

PL/SQL procedure successfully completed.





/* 验证

是不是依照我们设计的规则 tab1 -> tab2 -> tab3 ->exit 完毕的。

*/





TYGER@ORCL>alter session set nls_date_format='yyyy-mm-dd hh24:mi:ss';





Session altered.





TYGER@ORCL>select * from tab1;





        ID CDATE               SDATE

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

         1 2014-06-06 13:14:24 2014-05-06 13:14:24





TYGER@ORCL>select * from tab2;





        ID CDATE               SDATE

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

         2 2014-07-06 13:14:25 2014-05-06 13:14:25





TYGER@ORCL>select * from tab3;





        ID CDATE               SDATE

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

         3 2014-08-06 13:14:25 2014-05-06 13:14:25





TYGER@ORCL>

oracle chain的更多相关文章

  1. EOS 资源汇总

    EOS 资源汇总     A curated list of EOS Ecosystem by [SuperONE](https://superone.io/) EOS 主网 超级节点 https:/ ...

  2. oracle锁等级以及解锁

    以下是两遍关于锁的介绍的文章,第一篇介绍锁等级以及常用操作,第二篇主要介绍了oracle中两个用以查询数据库任意对象的两个视图 一: http://www.cnblogs.com/lguyss/arc ...

  3. Oracle Tuning 基础概述01 - Oracle 常见等待事件

    对Oracle数据库整体性能的优化,首先要关注的是在有性能问题时数据库排名前几位等待事件是哪些.Oracle等待事件众多,随着版本的升级,数量还在不断增加,可以通过v$event_name查到当前数据 ...

  4. Oracle Database 11g Release 2(11.2.0.3.0) RAC On Redhat Linux 5.8 Using Vmware Workstation 9.0

    一,简介 二,配置虚拟机 1,创建虚拟机 (1)添加三块儿网卡:   主节点 二节点 eth0:    公网  192.168.1.20/24   NAT eth0:    公网  192.168.1 ...

  5. [转]Oracle数据块体系的详细介绍

    数据块概述Oracle对数据库数据文件(datafile)中的存储空间进行管理的单位是数据块(data block).数据块是数据库中最小的(逻辑)数据单位.与数据块对应的,所有数据在操作系统级的最小 ...

  6. oracle实例恢复之检查点队列

    chain即链. oracle中链有很多种,LRU.LRUW.checkpoint queue等,都是干什么的呢??? LRU将可用块(干净的块)串起来.LRUW将脏块串起来,指导DBWR进程率先将冷 ...

  7. ORACLE工作原理小结

    ORACLE工作原理1-连接 我们从一个用户请求开始讲,ORACLE的完整的工作机制是怎样的,首先一个用户进程发出一个连接请求,如果使用的是主机命名或者是本地服务命中的主机名使用的是机器名(非IP地址 ...

  8. Oracle EBS R12 (12.1.3) Installation Linux(64 bit)

    Oracle EBS R12 (12.1.3) Installation Linux(64 bit) Contents Objective. 3 1 Download & Unzip. 3 D ...

  9. Oracle Hang分析--转载

    1. 数据库hang的几种可能性 oracle 死锁 或者系统负载非常高比如cpu使用或其他一些锁等待很高都可能导致系统hang住,比如大量的DX锁. 通常来说,我们所指的系统hang住,是指应用无响 ...

随机推荐

  1. H5性能调优

    概述 PC优化手段在Mobile侧同样适用 在Mobile侧我们提出三秒种渲染完成首屏指标 基于第二点,首屏加载3秒完成或使用Loading 基于联通3G网络平均338KB/s(2.71Mb/s),所 ...

  2. AngularJS, Ember.js, Backbone这类新框架与 jQuery的重要区别在哪里?

    jQuery主要是用来操作DOM的,如果单单说jQuery的话就是这样一个功能,它的插件也比较多,大家也都各自专注一个功能,可以说jQuery体系是跟着前端页面从静态到动态崛起的一个产物,他的作用就是 ...

  3. UVA 111 (复习dp, 14.07.09)

     History Grading  Background Many problems in Computer Science involve maximizing some measure accor ...

  4. C++11之右值引用(三):使用C++11编写string类以及“异常安全”的=运算符

    前面两节,说明了右值引用和它的作用.下面通过一个string类的编写,来说明右值引用的使用. 相对于C++98,主要是多了移动构造函数和移动赋值运算符. 先给出一个简要的声明: class Strin ...

  5. 网络编程 TCP学习

    上传txt文本 通过socket向服务端发送数据 然后用serversocket 接收socket 通过流读取数据保存 服务端在发送确认信息并在client输出 client import java. ...

  6. Squid 启动/停止/重载配置文件 命令

    当你的 squid.conf 配置文档按照你的想法修改完以后,启动 squid 之旅就开始了. Squid安装设试命令: 1,初始化你在 squid.conf 里配置的 cache 目录 #/usr/ ...

  7. MySQL优化时可以设置的几个参数

    back_log:back_log值指出在MySQL暂时停止回答新请求之前的短时间内多少个请求可以被存在堆栈中.也就是说,如果MySql的连接数据达到max_connections时,新来的请求将会被 ...

  8. Atitit.jdk java8的语法特性详解 attilax 总结

    Atitit.jdk java8的语法特性详解 attilax 总结 1.1. 类型推断这个特别有趣的.鲜为人知的特性1 2. Lambda1 2.1. 内部迭代意味着改由Java类库来进行迭代,而不 ...

  9. explicit 构造函数

    一.构造函数.默认构造函数.合成的默认构造函数 构造函数,是函数名与类名同样.没有返回类型的特殊的成员函数.能够有初始化列表. 默认构造函数,没有形參.或全部形參都有默认实參的构造函数. 假设没有显示 ...

  10. hdu 3172 Virtual Friends(并查集,字典树)

    题意:人与人交友构成关系网,两个人交友,相当于两个朋友圈的合并,问每个出两人,他们目前所在的关系网中的人数. 分析:用并查集,其实就是求每个集合当前的人数.对于人名的处理用到了字典树. 注意:1.题目 ...