oracle workflow 详解

原文地址:http://hutianci.iteye.com/blog/1023363

1概述... 2
1.1工作流的概念... 2
1.2工作流的目的... 2
1.3工作流体系结构:... 2
1.4工作流开发工具安装... 2
2工作流的组成及创建... 2
2.1单据类型(Item Type)... 3
2.2属性(Attribute)... 4
2.2.1定义一个URL属性... 6
2.2.2定义一个Form属性... 6
2.2.3定义一个Document属性... 7
2.3流程(Process)... 7
2.3.1在你画流程图之前,你必须先定义一个流程活动来表达流程图:... 7
2.3.2画流程图... 8
2.4消息(Message)... 10
2.5函数(Function)... 12
2.6通知(Notification)... 13
2.7查找类型(Lookup Type)... 14
3工作流引擎... 15
3.1概览... 15
3.2启动工作流流程... 16
3.3活动的状态... 16
3.4通知工作流引擎... 16
3.5工作流引擎的数据库包... 16
3.6工作流相关的主要表结构... 17

1.1工作流的概念

Workflow是EBS的基础架构技术之一,系统中大部分流程性的通知和审批控制、账户按规则自动生成都是通过Workflow实现的
1.2工作流的目的

  • 1. 在业务流程中发送、提供附加信息,这些附加信息以自助的Web页面或Form的形式存在,例如:在Application中审批采购订单时,采购订单的form会作为附加信息提供给审批人。
  • 2. 定义业务规则。使用WorkflowBuilder(图形化工具)修改业务规则的流程;使用PL/SQL写流程中活动的源代码
  • 3. 发送电子邮件。工作流可以以电子邮件的方式向任何Application的用户发送通知。

1.3工作流体系结构

  • 1. 开发者客户端:只要在PC上安装了WorkflowBuilder并且可以连接到数据库,就可以用来创建和修改工作流的定义。
  • 2. 数据库服务器:工作流是和Oracle的数据库集成在一起的。
  • 3. 应用服务器:包括Oracle Web Server、WebDB以及发送电子邮件的后台程序
  • 4. 最终用户端:安装了浏览器可以使用Application、接收工作流发出的邮件和使用用来监控工作流的Web页面。

1.4工作流开发工具安装
在http://www.oracle.com/technology ... workflow/index.html下载页面上找到workflow client并下载下来,即为所要安装的Workflow Builder。
WorkflowBuilder介绍:
用来定义和修改工作流的图形化工具,运行在Windows操作系统上。可以将一个或几个工作流的定义保存到数据库中或保存成一个文件
WorkflowBuilder由‘对象浏览器'和‘流程图表' 两种窗口构成。‘对象浏览器'以树状结构显示了工作流的对象构成,最上面一层是一个数据库连接或一个wft文件,下面一层显示的是在数据库或文件中包含的工作流定义,更下面一层的是构成一个完整的工作流定义的对象(例如:属性、流程、功能、通知、消息和快速编码)。‘流程图表'窗口使用‘对象浏览器'窗口中的对象来创建和修改工作流中的流程。
工作流的流程是由活动(活动可以是功能、通知或另一个工作流流程)和各活动之间的连线构成的。在应用中可以通过工作流引擎的API来调用一个工作流的流程。一个工作流的流程开始于一个‘开始'的活动。工作流引擎会自动地一个接一个地运行流程中的活动,直到遇到一个通知或一个暂停工作流流程的活动。当工作流引擎遇到一个通知时,它会调用通知程序来发送信息给某个角色,当用户或角色对通知作了回应,工作流引擎会接着运行后面的活动,直到遇到一个‘结束'活动。
在工作流的流程中可以使用循环、分支和平行结构以及使用子流程来实现复杂的业务规则。

2工作流的组成及创建
在Workflow Builder的对象浏览器窗口中以树状的方式显示了工作流的对象的组成,在树状结构的第三层(也就是项目类型的下面一层),包含以下这些分支:属性(Attribute)、流程(或子流程Process)、功能(Function)、通知(Notification)、信息(Message)和快速编码(Lookup Types);一个完整的工作流的定义就是由这些对象构成的。

2.1单据类型(Item Type)
组成工作流的对象的集合,在工作流流程中的每一个对象都必须从属于一个项目类型。企业的业务有很多类别,同一种业务对应有不同的业务流程,同时在业务流转的过程中处理不同的业务信息。单据类型其实就相当于一个业务类型。
单据类型属性主要是定义业务信息,另外还包含一些在其它对象需要引用的信息,例如通知里的接收人就可以作为单据类型的属性。单据类型的另外一项功能就是对工作流程进行分类 ,所有工作流里的其它对象都属于一个单据类型。
Item Type是个抽象的概念,为方便理解,可以看作就是一个工作流。
创建一个Item Type:

  • § 如果你没有打开一个data store,从File里选择New菜单创建一个新的Data Store,然后从鼠标右键菜单里选择New Item Type在浏览树里定义一个新的Item Type,此时单据类型的属性页会出现;

  • § 每一个单据类型有一个大写的内部名称,最多8个字符,所有的工作流API、PL/SQL过程,SQL脚本在识别单据类型的时候都引用单据类型的内部名称。在内部名称里不能包括":"和"/"。 Internal Name相当于Code,在程序中经常用它来标志一个工作流;
  • § 输入一个翻译性的名字,该名字是一个长一些的描述性名称,Display Name相当于User Name,你也可以在Description中为单据类型输入一段摘要信息;
  • § 指定单据类型的持续类型,Persistence:当你定义一个单据类型时,你必须指定它的Persistence Type,它主要是控制单据类型实例的状态审核追踪的保存时间,如果你把持续类型设置为Permanent,则运行时的状态信息会一直保存,除非你调用WF_Purge.Totalperm()过程清除;如果你把持续类型设置为Temporary,你必须指定持续的天数,临时持续类型的单据类型实例在完成之后至少保存你指定的持续天数,在'n'天过后,你可以调用任何一个WF_Purge的API清除单据类型的运行时信息。;
  • § Selector:如果你的单据类型有或者将有多个可运行的流程活动,定义一个PL/SQL函数决定在一个特殊的条件下运行哪一个流程活动。你也可以扩展这个选择函数为一个回调函数,这样在流程执行的过程中,如果会话信息中断的话,可以恢复单据类型实例的上下文信息。当你从通知详细页面上去查看一个页面属性时特别有用;
  • § 选择"Roles"页规定能访问单据类型的角色(没有用过);
  • § 选择"Access"页规定单据类型的访问和定制级别;
  • § 选择"应用"保存你的修改;
  • § 在浏览树里会出现一个二级分支来表示你刚创建的单据类型,你可以在浏览树里双击单据类型浏览或修改单据类型的属性;

2.2属性(Attribute)

就好像PL/SQL中的全局变量,它可以全局地被工作流流程中的活动引用(例如:在审批采购订单的工作流流程中,采购订单的编号就是一个项目类型属性,在审批流程的活动中可以随时获得这个属性的值,也就是采购订单的编号)。

单据类型属性是和单据类型联系在一起的,它通常充当一个全局变量,可以被流程里的活动引用或者修改。单据类型属性包含流程完成所必需的单据信息。对于活动需要引用的信息或者通知消息里包含的信息,你通常需要定义一个单据类型属性。
创建一个Attribute:

  • § 选中Item Type 子树中的Attribute/右键/New Attribute,出现属性页面

  • § 输入一个大写的内部名称;
  • § 输入一个显示名称,该名称会出现在浏览树里;
  • § 你可以输入一段描述摘要信息;
  • § 选择属性的数据类型,在定义活动属性的时候,没有Form,URL,Document属性类型。一般情况下可选以下几项:

属性具有10种类型,下面给出每种类型的说明:

  • Oslash; Text:属性的值是一个字符串文本;
  • Oslash; Number:属性的值是一个数字,你可以为数字类型的属性定义一个格式掩码;
  • Oslash; Date:属性的值是一个日期类型,你也可以为日期类型的属性定义一个格式掩码;
  • Oslash; Lookup:属性的值是一个查找类型的代码
  • Oslash; Form:属性的值是一个Oracle应用的内部窗体函数名称以及函数的参数;如果你在通知消息里包括了一个窗体类型的属性,在查看通知的时候,会显示一个窗体附件的图标,可以让用户浏览到相应的页面。
  • Oslash; URL:属性的值是一个网络的URL地址,如果你在通知活动里包含了一个URL引用属性,在查看通知的时候,会有一个指向URL的标识,用户可以完成活动也可以访问URL地址或的额外的信息。
  • Oslash; Document:属性的值是一个附件文档,你可以在默认值里指定文档的类型:PL/SQL文档,通过存储过程把数据库里的信息以文档的方式表达;DM文档,一个被外部文档管理系统管理的文档。
  • Oslash; Role:属性的值是一个角色的内部名称,如果在一个通知里包含了一个角色类型的属性,则该属性会自动解释为角色的显示名称,省去了在内部名称和外部名称之间维护的工作。为了给角色类型的属性赋一个默认值,你必须首先从数据库里装载角色。
  • Oslash; Attribute:属性类型的值是对单据类型的引用。
  • Oslash; Event:暂时不知?(没有查到相关资料
  • § 根据你选择的属性类型,为属性指定默认值信息;
  • § 对单据类型属性来说,可选的默认值是一个你输入或从列表中选择的常量,不过,这个常量可以是一个在运行时替换的字符串;对活动属性来说,默认值可以是一个常量或者一个单据类型属性;
  • § 选择"应用"保存你的修改,选择"确定"保存你的修改并推出属性页面,"取消"取消你的修改并推出属性页面;
  • § 如果你在定义一个单据类型属性,选择"Access"页设置允许修改属性的访问级别。

你创建的任何Attributes类型会出现在浏览树的"Attributes"分支下,所有的函数属性出现在对应的函数下面,你可以从浏览树里双击一个属性浏览或修改属性的定义。
2.2.1定义一个URL属性

  • § 在属性默认值里指定一个URL地址,这个URL可以是一个常量或者一个从其它单据属性返回的值;
  • § 你也可以在URL里包含字符串参数,这个参数可以是一个字符串文本或一个其它单据类型的格式替换。在参数字符串里采用其它单据类型进行格式替换,需要采用如下的格式:item_attr;
  • § 如果URL里包含一个参数字符串,你必须遵守如下的限制:你不能用一个文档类型的单据类型属性对参数进行格式替换;你可以用表单或URL属性对参数进行格式替换,但不能进行嵌套替换;
  • § 如果你需要在URL里传递一个日期时间参数,你需要使用TO_CHAR函数把日期时间转换为如下格式:"YYYY-MM-DD+HH24:MM:SS",同样对日起类型需要使用TO_DATE;
  • § 结束工作之后选择"确定"按钮保存。

2.2.2定义一个Form属性

  • § 在窗体属性页的默认值里指定一个窗体函数的名称以及可选的字符串参数(窗体函数的参数);
  • § 默认值必须使用下面的格式输入:function_name:arg1=value1 arg2=value2...argn=valuen,argn的值可以是一个包含在双引号内的字符串,也可以是一个被其他单据类型属性进行格式替换的值,可以使用下面的方式定义格式替换:argn="item_attr"或者argn="value &item_attr";
  • § 如果你的窗体属性内包括参数,你必须牢记以下的限制:你不能使用一个文档类型的属性进行标记替换;你可以使用一个窗体类型或URL类型的属性进行标记替换,但是你不能进行嵌套替换;
  • § 保存你的工作。

2.2.3定义一个Document属性

  • § 在属性页的默认值里输入一个标识文档的字符串;
  • § 你可以标识以下两种类型的文档:PL/SQL文档或者存放在文档管理系统里的文档;
  • § 一个PL/SQL文档表示数据库里的数据,该文档由一个存储过程产生,需要使用下面的方式来指定一个PL/SQL文档的默认值:plsql:<procedure>/<document_identifier>。在使用时用一个包和过程名称来替换procedure,用直接传送给过程的字符串参数替换document_identifier,这个参数字符串应该能标识这个文档。PL/SQL存储过程必须按照标准的API格式来写;默认值的实例如下所示:plsql:po_wf.show_req/po_req:2034;
  • § 如果你想动态的生成一个PL/SQL文档,你可以把文档标识定义成一个标记替换,然后使用其它单据类型属性的值替换,例如:plsql:po_wf.show_req/item_attr1:&item_attr2;
  • § 如果想指定一个由外部文档管理系统管理的文档,可以在默认值里输入如下格式的信息:DM:<node_ID>:<document_ID>:[version];
  • § 选择"确定"保存你的修改。

2.3流程(Process)

流程就是业务流程的流转规则。流程包括两部分:流程里包含的活动和各个活动在不同条件下的流转关系。在定义流程的时候,因为流程里的活动可能有不同的返回结果,我们需要把不同结果的处理活动和结果联系起来,另外在OracleERP里还定义了一些标准的返回结果(例如超时),你在定义流程的时候,也可以对这些内嵌的返回结果进行处理。在流程实例流转的时候,流程里的活动有自己相应的状态,工作流引擎得到活动的状态改变信息或活动返回结果之后,按照你定义的流程流转规则控制流程的流转。流程必须属于一个单据类型。
流程定义里有一个标志属性"是否可运行标志",如果一个流程是可运行的,则可以在窗体上可以直接调用,否则该流程只能作为一个子流程包含在其它的流程里面,工作流引擎在碰到流程活动的时候,会自动激活子流程,让子流程流转。
2.3.1在你画流程图之前,你必须先定义一个流程活动来表达流程图:

  • § 从浏览树里选择一个单据类型,右键Process并从菜单里选择"New Process",在活动属性页上定义流程活动信息;
  • § 流程活动必须有一个全部大写的内部名称和一个显示名称,你也可以输入一段摘要信息来描述这个活动;
  • § 指定流程活动的结果类型,流程活动可以不返回结果;
  • § 为流程活动选择一个图标来标识它;
  • § 选中Runnable,这样你就可以把流程当作一个独立的流程来运行,如果不选的话,定义的流程只能作为一个子流程在别的流程下运行;
  • § 保存你的工作;
  • § 选择"Details"页定义流程活动的详细信息;
  • § 选择"Access"页指定允许修改流程的访问级别;
  • § 保存你所作的修改;
  • § 在浏览树的"Processes"分支下回出现你新定义的流程,在浏览树里用鼠标双击流程就可以查看和修改流程活动的信息。

2.3.2画流程图
在Oracle Workflow Builder里,流程图采用一种图形化的方式来显示流程里的活动以及活动之间的转移。在流程图里用一个图标来表示活动,用一个箭头来表示活动之间的转移。你可以从浏览树里把一个活动拖拽到流程图里,也可以直接在流程图里创建一个活动,在流程图里双击一个活动节点可以查看或修改节点的信息。通过在两个活动之间画一个箭头来表示活动之间的转移。
转移在流程图里使用一个箭头表示的,它表示一个活动的结束以及另外一个活动的激活。如果一个活动的结果类型是None,则转移表现为一个指向另外一个活动的箭头,表示只要初始的活动一结束,就流向下一个活动。如果一个活动有返回结果类型,则你必须把转移和活动的一个结果联系起来,你也可以为定义了返回结果的活动定义下面的转移类型:Default,Any,Timeout。在没有任何转移匹配完成结果时,工作流引擎执行默认的转移;如果定义了一个人以的转移,则不论活动的返回结果是什么,工作流引擎就执行这个转移,这样可以保证你除了在工作流里执行和放返回结果对应的活动外,还可以执行一个通用的活动。如果一个活动在完成之前已经超时,则工作流引擎执行超时转移。一个活动的返回结果可以有多个转移来进行并行处理。
(1)增加一个节点

  • § 在开始画流程图之前,你必须先显示流程活动的流程窗口,你可以通过以下的方式显示流程窗口:在浏览树里双击一个定义好的流程活动;选择一个定义好的流程活动并按下Ctrl+E;选择一个流程活动,并从编辑菜单里选择流程详细信息;使用快速启动向导创建一个新的流程。
  • § 可以通过下面的方式创建一个节点:从浏览树里拖拽一个活动;选择New Function、New Notification、New Process工具栏按钮创建一个节点;在弹出菜单里选择Create Activity创建一个新的节点;
  • § 按住鼠标右健并把鼠标从一个活动拖到另一个活动就在两个活动之间创建了一个转移;
  • § 如果来源活动定义了放回结果类型,则需要把转移和一个结果联系起来;
  • § 你可以在流程图里进行Copy和Paste;

(2)定义一个节点

  • § 打开流程活动的流程窗口;
  • § 使用工具栏按钮创建一个新的活动;
  • § 在单据类型域里,选择一个单据类型;
  • § 采用下面的方式定义节点的剩余信息:选择一个已定义活动的内部名称或显示名称,Workflow Builder会自动显示出原来定义的信息;另外你也可以使用新建按钮来创建一个新的活动,并根据活动的类型分别定义它们的信息,注意,在流程图里说做的修改都会反映到浏览树里的活动信息里;

  • § 选择"Node"页来定义节点的特定信息,为节点指定一个标签,因为一个活动在一个流程里可能有多个实例,可以通过标签来区分同一个活动的不同实例;
  • § 指定节点是否为一个开始或结束节点;
  • § 如果流程有一个接过类型,你必须为结束节点指定一个最终的结果;
  • § 你可以提供一段注释信息供自己察看;
  • § 对一个通知或一个子流程活动,你可以规定该活动节点是否必须在规定的时间之内完成;
  • § 对一个通知节点来说,你可以覆盖同志消息的优先级,另外需要给通知活动指定一个执行者,这是一个角色;
  • § 保存你的修改;
  • § 如果节点是一个函数或通知活动,并且这个活动有参数,你可以选择节点属性页给这些活动属性赋值;

如果这个节点是一个子流程,则一个子流程的标识会出现在子流程节点图标上。

  • (3)定义活动属性值

活动属性值主要是别PL/SQL存储过程服务的,这个存储过程被函数或通知活动调用。

  • § 显示属性值页;
  • § 选择一个属性;
  • § 在值区域里,输入这个属性的值,这个值可以是一个常量也可以是一个对单据类型属性的引用。注意,这个值的类型必须和活动属性的类型以及存储过程参数的类型保持一致;
  • § 保存你的修改。

2.4消息(Message)
消息主要是为通知服务的,可以把消息当作通知的内容和类型。消息也属于一个单据类型,通知只能和同一个单据类型里的消息相关联。
每个消息可以有一个或多个属性和自己相联系,消息的属性既可以是独立的属性,也可以是对单据类型属性的一个引用。在消息体内可以对消息的属性进行引用,这样在流程的实例里,如果已经对消息的属性赋值,则在引用消息属性的地方会自动的用消息属性的值替换。我们就可以在消息体内显示必要的信息。
你可以对一个消息定义自动流转规则,这样在工作流的实例里,当流转到和该消息对应的通知活动的时候,工作流引擎就会根据用户定义的自动流转规则自动向下流转,用户就不需要参与了。
消息时工作流程里通知活动发送给角色的内容,消息可以提示户对通知进行回复或者让用户采取一个动作决定下一个活动,在工作流里一个消息的接收者被称作"Performer";每个消息都和一个单据类型联系在一起,这样可以允许消息引用单据类型属性,在运行时进行标记替换。
当你定义消息的时候,可以指定接收者回复的值,然后工作流引擎根据用户的返回值决定流程的下一个活动,你也可以在消息的主题和消息体内包括消息属性使消息成为一个上下文环境敏感的消息。你可以从浏览树里直接把一个消息直接拖拽到通知分支下面创建一个发送该消息的通知,也可以把消息拖拽到一个已存在的通知活动上更新通知发送的消息。
当你为通知活动创建一个通知的时候,你需要注意通知是否规定了一个结果类型,如果有结果类型的话,你创建的通知需要提示通知接收者一些特定的响应用来解释通知的结果类型,工作流引擎使用这些结果决定流程需要流到哪些活动。要想创建一个对特殊响应进行提示的消息,你需要完成消息页面的"Result"页,你输入的信息创建了一个特殊的"Response"消息属性,它有一个内部名称"RESULT",结果消息属性的数据类型是一个查找类型,并且必须和通知的结果查找类型一致,这可以保证通知活动的执行者从一个通知活动期望的结果值列表里选择一个值。
一旦你创建了一个消息,你可以为消息定义需要的所有属性,在浏览树里消息的属性存放在消息的下面。消息属性的来源(Send or  Respond)决定了消息属性的使用方式,你可以使用"Send"类型的消息属性进行标记替换或者和消息一块发送。每个消息类型都有一个数据类型,"Send"类型的消息属性可以是一个常量或者是一个对单据类型属性的引用。"Response"类型的消息属性组成了消息的响应部分,响应消息属性为接收者的响应提供了指令。如果你定义了一个响应消息属性,你必须给它指定数据类型,你也可以给它指定一个默认值,默认值可以是一个常量,也可以是对相同数据类型单据类型属性的引用。
创建一个消息:

  • § 从浏览树里选择一个单据类型子树中的Messages,然后右键并从菜单里选择"New Message",消息属性页面就会出现;

  • § 为消息提供一个大写的内部名称,一个显示名称,你可以为消息输入一段描述性的信息;
  • § 为消息选择一个默认的优先级,消息的优先级只是提醒接收者消息的紧急程度,对消息的传送和处理没有影响;
  • § 保存你的修改;

  • § 选择"Body"页定义消息体;
  • § 主题会有一个和消息显示名称一样的默认值,你可以保存这个默认的主题或者输入一个新的主题,消息的主题可以包含消息的属性,在运行时通过标记替换来赋值。
  • § 在消息体输入框内输入一段纯文本信息,Oracle工作流使用你输入的文本生成通知消息的一个文本版本,这段文本消息可以从一个E-mail阅读器里查看;
  • § 你也可以输入一个HTML格式的消息体,同时也可以从一个HTML文件里导入,注意,当你输入或导入HTML文件的时候,不要包括<Body>...</Body>HTML标记,如果你包括了这些标记,Oracle工作流只是简单的抽取这些标记之间的内容,<Body>标记之前的内容。Oracle工作流使用你在HTML消息体内的内容为通知消息生成一个HTML格式的版本,你可以从通知的详细页面来查看HTML格式的通知消息或者从一个E-mail阅读器来查看HTML格式的消息或者HTML格式的附件,如果你的HTML消息体的内容是空的,工作流会使用你在文本消息体内输入的内容生成通知消息。另外一个需要注意的问题是,Oracle工作流不能识别消息体内的图标和图像文件。
  • § 你可以再消息体内包括消息的属性,这样在运行的时候,可以使用消息属性的值进行标记替换。
  • § 保存你所作的修改。
  • § 选择"Role"页面规定访问该消息的角色信息;
  • § 选择"Access"页面规定允许修改消息的访问级别;
  • § 如果你想让通知消息提示"Performer"返回一个结果值并且希望Oracle工作流引擎把消息的结果值解释为通知活动的返回结果值,你需要选择"Result"页完成要求的信息,Oracle工作流使用你在该页面上输入的信息生成一个叫做"Result"的特殊"Response"类型的消息属性;在该页面上输入一个显示名称和一段描述性的信息,并在列表里选择一个查找类型,你选择的查找类型应该和通知或定的结果查找类型一致,在默认值区域里选择一个查找类型编码;
  • § 保存你所作的修改;
  • § 你刚定义的消息会出现在浏览树的Messages分支下面,你可以双击这个消息来查看或修改消息的信息;
  • § 你必须定义所有包含在消息主题和消息体内的消息属性;
  • § 如果你想创建一个引用单据类型属性的消息,从浏览树里选择一个单据类型属性并把它用鼠标拖拽到消息上,你必须在消息属性窗口里编辑该属性,确保消息属性有正确的来源。默认值区域会自动的设置成单据属性并引用原始的单据属性;
  • § 你也可以创建一个不引用已存在单据类型属性的消息属性;

2.5函数(Function)
函数就是一个可以自动执行的活动,该活动可以完成一定的功能,函数活动通常和一个PL/SQL存储过程或者一个Oracle内部的过程联系在一起,在定义函数活动的时候必须定义该函数对应的过程名称。
函数类型的活动有自己的参数定义,函数活动的参数主要是为对应的过程服务的。在运行的时候通过给函数活动的参数赋值,经过相应的处理之后,工作流引擎就会把函数活动的参数值传给相应的过程,这样就能保证函数的正确执行。如果对应的过程没有参数的话,可以不定义参数。
创建一个Function:

  • § 从浏览树选择一个单据类型,右键Function并从菜单里选择"New Function",在活动属性页里定义函数活动的信息;

  • § 为函数活动提供一个大写的内部名称以及显示名称,你也可以一段描述活动的摘要信息;
  • § 输入函数活动执行的函数名称,并选择函数的类型;
  • § 选择函数活动的结果类型,
  • § 输入函数活动的时间花费;
  • § 选择一个标识函数活动的图标;
  • § 保存你的修改
  • § 选择"Details"页面显示或修改活动的详细信息;
  • § 选择"Roles"页面制定访问活动的角色信息(这个功能可能在将来的版本里支持);
  • § 选择"Access"页面规定允许修改活动的访问信息;
  • § 新定义的函数活动会出现在浏览树里的"Functions"分支下面,你可以用鼠标双击这个函数活动来查看和修改函数活动的信息。
  • § 如果你的函数需要输入参数,你可以为函数活动定属性。

2.6通知(Notification)
通知活动对一个人或一个角色发送一个通知,通知必须和一个消息联系在一起。通知活动有自己的结果类型,返回的结果一般是根据用户的交互产生的,除非你在消息里定义了自动流转规则。
创建一个Notification:

  • § 从浏览树里选择一个单据类型,右键Notification并从菜单里选择"New Notification",在出现的活动窗口里定义通知活动;

  • § 通知活动必须有一个大写的内部名称,另外还必须有一个显示名称,你也可以为通知定义一段描述信息对通知活动进行描述。
  • § 指定通知活动的结果类型(一个定义好的查找类型),结果类型是一个可能返回结果的列表,你的工作流会根据活动的返回结果进行分支处理。你的通知活动也可以没有返回结果。
  • § 选择你的通知想发送的消息名称;
  • § 如果你想把通知指定给一个包含多个人的角色,并且给角色里的每一个人发送一份通知的拷贝,选择"Expand Role",如果你把选择该选项,就给整个角色发送一个通知的拷贝。
  • § 你可以在"Function"域里指定一个PL/SQL存储过程,这就是一个"Post-Function"函数,工作流引擎会根据用户的响应在不同的模式下执行这个函数,可能的模式类型有:Respond、Forward、Time Out和Transfer;
  • § 为活动选择一个图标按钮,便于在流程图里标识活动;
  • § 保存你的修改;
  • § 选择"Details"页面显示或修改活动的详细信息;
  • § 选择"Roles"页面制定访问活动的角色信息(这个功能可能在将来的版本里支持);
  • § 选择"Access"页面规定允许修改活动的访问信息;
  • § 保存你的修改;
  • § 新定义的通知活动会出现在浏览树里的"Notifications"分支下面,你可以用鼠标双击这个通知活动来查看和修改通知活动的信息。


2.7查找类型(Lookup Type)
查找类型是你定义的一些枚举数据,单据类型里的查找类型主要用来表达活动结果返回值类型,另外也可以在定义单据类型属性、活动属性、消息和消息属性时引用查找类型,一个查找类型有自己相应的值列表,在引用查找类型的时候,你只需要定义查找类型就可以了,和查找类型相关的值会自动过去的。
查找类型是一个静态值列表,这些列表可以被活动、单据类型、消息或属性引用,例如一个活动可以引用一个查找类型作为它可能的返回值。
当你定义一个查找类型的时候,你必须把它和一个单据类型联系起来;然而,但你在创建一个活动或属性的时候,你可以引用但前数据存储里的任何查找类型,不论这个查找类型和哪个单据类型联系在一起。
    创建一个Lookup Type:

  • § 从浏览树里选择一个单据类型,然后右键从菜单中选择"New",一个查找类型属性页就会出现;

  • § 查找类型有一个大写的内部名称、一个显示名称,你也可以输入一段描述性的摘要信息,在引用查找类型的时候,需要指定它的内部名称;
  • § 选择"Access"页定义允许修改查找类型的访问级别;
  • § 保存你的修改;
  • § 新定义的查找类型会出现在浏览树的"Lookup Types"分支下面,你可以在今后双击该查找类型来查看和修改它的属性;
  • § 为查找类型定义编码:
  • Oslash; 选择一个查找类型,右键并从菜单里选择"New Lookup Code",一个查找编码属性页会出现;

  • Oslash; 输入大写的内部名称、显示名称,你也可以输入一段摘要信息;
  • Oslash; 保存你的修改;
  • Oslash; 新定义的查找类型编码会在相对应的查找类型下面出现。

 

3工作流引擎

3.1概览

  • Oslash; 工作流引擎是运行在数据库服务器端的PL/SQL程序
  • Oslash; 工作流引擎任何时候都处于激活状态,只要它的PL/SQL过程或函数被调用
  • Oslash; 工作流引擎管理着每个工作流流程实例的活动
  • Oslash; 当一个活动完成后,工作流引擎决定了下一个将被运行的活动
  • Oslash; 工作流引擎自动执行工作流的功能活动
  • Oslash; 工作流引擎会调用通知系统用户发送通知(通知系统也是运行在服务器端的PL/SQL程序,它可以和ORACLE的WEB代理进行接口或者通过 ‘通知邮递员'程序来给最终用户发通知)。
  • Oslash; 将对系统资源消耗比较大的活动推迟,由后台引擎来运行
  • Oslash; 侦测错误并执行处理错误的流程

3.2启动工作流流程

要在应用中调用工作流的流程(例如:在采购订单的FORM中调用‘审批采购订单'的工作流流程),必须在应用的程序中使用启动工作流流程的工作流引擎API:调用WF_ENGINE.CreateProcess接着调用WF_ENGINE.StartProcess或单独调用WF_ENGINE.LaunchProcess。在这些API中都必须指定ITEM_TYPE和ITEM_KEY的值作为参数。

3.3活动的状态

当工作流引擎执行一个活动时,它将修改活动的状态为以下的值之一:
  • Oslash; Active:活动当前正在被执行,例如主流程活动一直处于活动状态直到盖流程中的所有活动都已完成
  • Oslash; Complete:活动已经执行完毕,并且执行成功
  • Oslash; Waiting:活动正等待相关活动的完成,一个活动尽管已经运行结束,但它必须等待相关的活动也运行结束才能被标记为Complete
  • Oslash; Notified:活动正在等待通知的回应
  • Oslash; Deferred:活动被推迟到后台运行
  • Oslash; Error:活动在执行过程中出错
  • Oslash; Suspend:活动被暂挂,在暂挂被取消后将继续运行

3.4通知工作流引擎

在一个活动结束后必须通知工作流引擎。流程、通知和功能活动结束后会自动调用WF_ENGINE.CompleteActivity来通知工作流引擎它们已经运行结束。如果一个功能活动调用的是一段外部程序,那么外部程序需要调用WF_ENGINE.CompleteActivity,在活动结束的时候。

3.5工作流引擎的数据库

工作流引擎是由一些PL/SQL的数据库包组成的,大致包括:
  • ü WF_ENGINE:用来启动和运行工作流流程,获取、写入或创建项目类型Attribute、功能活动Attribute的值,管理活动的状态
  • ü WF_CORE:触发和捕获错误
  • ü WF_PURGE:清除无用的运行的中间数据
  • ü WF_DIRECTORY:用来存入和获取目录服务的信息
  • ü WF_MONITOR:生成工作流监控页面的URL
  • ü WF_NOTIFICATION:管理工作流的通知
  • ü WF_PREFERENCE:检索用户的偏好信息
3.6工作流相关的主要表结构
  • Oslash; wf_item_types_vl

保存工作流的定义,即类(大的种类,如:OEOH、OEOL)

  • Oslash; wf_activities

保存当前系统中的工作流的名称(一个版本一条信息)

  • Oslash; wf_items

保存实际的工作流,或者说工作流的对象实例

例如:每当生成一条SO时,系统往里面插入一条记录(一行一条记录)

  • Oslash; wf_process_activities

工作流每个NODE的属性信息

  • u process_item_type : item_type
  • u PROCESS_NAME : 工作流的名称
  • u PROCESS_VERSION :工作流的版本信息
  • u ACTIVITY_ITEM_TYPE : 节点的ITEM类型
  • u ACTIVITY_NAME : 节点 ITEM 的名称
  • u INSTANCE_ID : 节点 ID
  • u INSTANCE_LABEL : 节点显示的 LABEL 标记
  • Oslash; WF_ACTIVITY_ATTRIBUTES

保存工作流实例的attribute最新值

  • Oslash; wf_item_activity_statuses

保存工作流实例的各个activity的状态,比如完成否,返回值

  • Oslash; wf_notifications

保存工作流实例的notifications消息,基本是按顺序的,可以看发给谁了

  • Oslash; wf_roles

角色视图,工作流引用角色的依据,有mail地址等信息

  • Oslash; wf_user_roles

用户和角色关系视图,工作流可以根据它进行"群发"



总结:通过这几天对Oracle之Workflow的学习,主要是按照《深入浅出Oracle之Workflow实例详解》上面的实例操作,对工作流有了进一步的理解,本文档是我搜集网上的资料整理出来的,其中很多图例是对操作界面的讲解,不是实例,很多信息都是深入浅出里面没有的,希望对浏览的人有帮助

你可能感兴趣的:(oracle workflow 详解)