2014-06-01 Created By BaoXinjian

的默认访问级别是100,以下是Oracle对访问级别的一个大致分类:


0-9 Oracle Workflow 
10-19 Oracle Application Object Library
20-99 Oracle Application Development
100-999 Customer Organization
1000 Public

2. Oracle 工作流对象通过不同的选项和访问级别来实现对象的保护


安装


1、可以直接使用8i的http,不用安装IAS,根据Server安装指南配置httpd.conf的别名即可;http服务起不来的可能情况2、

httpd.conf语法错误,这个没什么好说的
    之前的服务没有正常结束,一般重新启动计算机即可;或者杀掉java进程,如果有的话
    新安装了Oracle其它产品,导致路径引用错误;我的解决办法是把新安装软件在环境变量Path中添加的路径移到最后
    如果要看httpd为何无法启动,查看Log是没用的;应该先运行CMD,然后cd到需要的目录,输入apache.exe,这个时候就会有错误出现
2、Notification默认的配置是html email,这个时候易遇到Notification就报错,

因为我们自己一般没有配置Mail服务器,所以需要在Global Workflow Preferences里面把Send me
electronic mail notifications设置为Do not send me mail
3、开始我没有配好Business Event System,在执行Aprove等动作的时候老是No Data Found;

后来我根据Error Stack找到wf_xml包,把里面的RemoveNotification的Raise语句注释掉就可以了。嘿嘿,反正我是自己研究工作流,无所谓了
4、我的系统是XP Home SP1,没有JVM,无法View Diagram;装了JDK,不太好用,卸掉装msjavx86.exe一切正常

刚接触Workflow Builder会碰到的几个疑问


如何连接各个Node:用右键而不是左键连

为何修改不了别人的文件:在Help菜单里面设置合适的Access Level

为何图标不起作用:在View菜单里面选择Develop Mode

如何使用Standard的Item:打开Standard或Demo文件,把Stantard这个Item Type抓过去

Notification根据什么发:必须在Process里面打开Notification的属性,Node标签里面有一个Performer,根据需要设置成我们预定义的某个Role类型的Attribute

Workflow
Builder的PL/SQL函数有什么要求:拷个Demo的函数,照着写就可以了,怎么判断运行模式,怎么返回里面都有

其他问题其实Workflow Builder在保存或者我们选择Verify的时候都会提示,只要认真看都能解决

对各个Item的通俗理解


1、Item Type是个抽象的概念,为方便理解,可以看作是一个工作流的容器和标志

2、Attribute是全局变量,供整个Item Type里面的元素使用,可以作为message的附加属性,Send给用户看或者存储用户的Response内容比如Note和Forward To;Attribute另一个常用的地方是作为Notification的Performer。当然我们的PL/SQL代码是离不开Attribute,几乎任何PL/SQL函数都需要通过取得Attribute变量--判断Attribute变量--设置Attribute变量,决定程序如何走,返回什么值

3、Message,就是一个消息,内容在Body里面定义,用&引用Message自己的Attribute;对我们程序有用的的是Message的Attribute,一般和上面的全局变量Attribute对应,Send类型的Attribute将取当时的全局变量Attribute的值发给用户看,Response类型Attribute将把用户输入的内容返回给全局变量Attribute供我们的程序作下一步判断使用

4、Lookup Types,基础字典列表,就像我们的部门字典表,销售方式字典表一样,不过它是静态的;根据需要设置,一般用来标志工作流各类Item的返回值,和我们的PL/SQL函数返回值一一对应

5、Function,就是Function,一个处理,一般对应一个PL/SQL函数并定义返回值为某个Lookup Type

6、Notification,发送一个消息,消息内容为定义的Message内容,消息的接收人是定义的Performer

7、Process,真正的流程,由Notification、Function、子Process组成,开始于一个Start Function,结束于一个或多个End Function,中间是Notification和Function组成的业务流程,在这个级别上可以把Notification、Function、子Process看成是一样的即activity,他们都有返回值,不同的结果走不同的流程,由此组成一个符合业务需要的图表

由Engine管理、不需要我们操心的东西


1、消息发送;我们只管定义,由于可以用HTML写Message的Body,可以定义得很漂亮

2、流程选择;我们只管按不同的返回结果画图,Engine会根据我们函数的返回值调用下一个activity

3、用户选择;我们可以修改wf_roles、wf_users、wf_user_roles这三个视图,使之包含我们业务系统的用户即可

常用表


1.Workflow Definition Tables

WF_ITEM_TYPES

WF_ACTIVITIES

WF_MESSAGES

WF_ITEM_ATTRIBUTES

WF_ACTIVITY_ATTRIBUTES

WF_MESSAGE_ATTRIBUTES

WF_PROCESS_ACTIVITIES

WF_ACTIVITY_TRANSITIONS

2. Workflow Runtime Tables

WF_ITEMS

WF_ITEM_ACTIVITY_STATUSES

WF_NOTIFICATIONS

WF_MESSAGES

WF_NOTIFICATION_ATTRIBUTES

3. Business Event Tables

WF_SYSTEMS

WF_AGENTS

WF_EVENTS

WF_EVENT_SUBSCRIPTIONS

4. 各表解析

wf_item_types_vl,保存工作流的定义,即类

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

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

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

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

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

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

签合层级


(1). Hierarchy头
    SELECT *
      FROM PER_POSITION_STRUCTURES_V PS
    WHERE PS.NAME = 'XXXXXXXX'; --64

(2).Hierarchy行
    SELECT *
      FROM PER_POS_STRUCTURE_ELEMENTS_V PE
    WHERE PE.POS_STRUCTURE_VERSION_ID = 64;

(3).Hierarchy生成表
    SELECT *
      FROM PO_EMPLOYEE_HIERARCHIES H
    WHERE H.POSITION_STRUCTURE_ID = 64
       AND H.EMPLOYEE_ID <> H.SUPERIOR_ID;

--职位表
    SELECT * FROM select * from PER_ALL_PEOPLE_F P WHERE P.NAME = 'YYYYY'; --93

--职位分配
    SELECT * FROM PER_ALL_ASSIGNMENTS_F A WHERE
A.POSITION_ID = 93; --960

--人员
    SELECT * FROM PER_ALL_PEOPLE_F AP WHERE AP.PERSON_ID =
960;

--请求
    Fill Employee Hierarchy

没有收到Notification


1. 程序错误,没有设置正确的Notification Performer

2. 如果是PO,可能没跑Fill Employee Hierarchy

3. 一个Employee分配给了多个User,那么其实只有第一个User收到了消息

4. 数据还没有同步到Workflow,即没跑Synchronize Workflow LOCAL tables

的类型


的必须建立


对于程序来说ID是关键的,来源于各个表如FND_USER或者HR_EMPLOYEES;

对于Workflow来说Name是关键的,来源于表WF_ROLES;

对于最终User来说,Display
Name是关键的,来源于表WF_ROLES;

隐藏Notification中的一些默认Button


#HIDE_REASSIGN,可以隐藏标准的Reassign按钮

#HIDE_MOREINFO,可以隐藏标准的Request
Information按钮

的Activity的节点的七个状态


Active--activity
is running.

Complete--activity
completed normally.

Waiting--activity
is waiting to run.

Notified--notification
activity is delivered and open.

Deferred--activity
is deferred.

Error--activity
completed with error.

Suspended--activity
is suspended.

Thanks and Regards

Workflow_工作流的基本概念(概念)的更多相关文章

  1. Workflow_工作流的基本元素(概念)

    2014-05-31 Created By BaoXinjian

  2. Airflow Python工作流引擎的重要概念介绍

    Airflow Python工作流引擎的重要概念介绍 - watermelonbig的专栏 - CSDN博客https://blog.csdn.net/watermelonbig/article/de ...

  3. Workflow_工作流发送Document和Form链接的实现(案例)

    2014-06-01 Created By BaoXinjian

  4. 工作流学习——重要概念扫盲篇一步曲 (zhuan)

    http://blog.csdn.net/zwk626542417/article/details/46592471 ***************************************** ...

  5. JBPM——工作流概念

    一.概念          工作流(Workflow),就是"业务过程的部分或总体在计算机应用环境下的自己主动化",它主要解决的是"使在多个參与者之间依照某种提前定义的规 ...

  6. ccflow关于流程引擎的父子流程的基本概念

    关键字:驰骋BPM jflow,ccflow, 驰骋工作流引擎 父子流程概念:在管理活动中,通用的部分,公用的部分,可以被重复执行的部分的流程管理活动我们把他独立出来,成为子流程,可以被其他流程的管理 ...

  7. .NET Remoting学习笔记(一)概念

    目录 .NET Remoting学习笔记(一)概念 .NET Remoting学习笔记(二)激活方式 .NET Remoting学习笔记(三)信道 背景 自接触编程以来,一直听过这个名词Remotin ...

  8. 4.事务提交过程,交易的基本概念,Oracle交易周期,保存点savepoint,数据库的隔离级别

     事务提交过程 事务 基本概念 概念:一个或者多个DML语言组成 特点:要么都成功.要么都失败 事务的隔离性:多个client同一时候操作数据库的时候.要隔离它们的操作, 否则出现:脏读  不可反 ...

  9. 【转载】.NET Remoting学习笔记(一)概念

    目录 .NET Remoting学习笔记(一)概念 .NET Remoting学习笔记(二)激活方式 .NET Remoting学习笔记(三)信道 背景 自接触编程以来,一直听过这个名词Remotin ...

随机推荐

  1. [置顶] think in java interview-高级开发人员面试宝典(一)

    “生死六重门” 无论你是在职,非在职,高级工程师,工程师,架构师,如果你正在面试阶段,请看完此文! 相信这篇文章对你的职业生涯和阶值观会造成重大的改变! 如果你是一名PM或者是管理者正在物色合适的开发 ...

  2. iOS开发-xCode6(iOS 8)中应用程序图标和启动页面设置

    iOS8中设置应用程序图标跟之前没有什么变化,命名规则不变,不过至于设置启动页面,网上给的方式很多都是模棱两可的,东平西凑总算是把启动页面的图片设置成功了,iOS设置启动图片有两种方式一种是Launc ...

  3. 11个JavaScript颜色选择器插件

    几年前,很难找到一个合适的颜色选择器.正好看到很多不错的JavaScript颜色选择器插件,故而把这些编译汇总.在本文,Web设计师和开发人员 Kevin Liew 选取了11个相应插件,有些会比较复 ...

  4. JSP简单练习-定时刷新页面

    <%@ page contentType="text/html; charset=gb2312" %> <%@ page import="java.ut ...

  5. Windows上使用“LogView”打开大文件

    最近因为工作需要要打开一个300+MB的文件,试过了N个编辑器不是打不开就是软件直接挂掉或是占用内存太大,已经严重影响了我的工作 还好在网络上找到老外写的一个免费软件,官网上说是可以打开4G+的文件( ...

  6. (转)U3D DrawCall优化手记

    自:http://www.cnblogs.com/ybgame/p/3588795.html 在最近,使用U3D开发的游戏核心部分功能即将完成,中间由于各种历史原因,导致项目存在比较大的问题,这些问题 ...

  7. vs2013 密钥_

    vs2013 密钥 最佳答案: BWG7X-J98B3-W34RT-33B3R-JVYW9

  8. java 反射获取属性值 方法

    public static void main(String[] args) throws SecurityException, ClassNotFoundException, IllegalArgu ...

  9. ZH奶酪:Word断字功能不可用。请运行Microsoft Office安装程序安装该功能,然后重试。

    断字功能就是英文单词遇到换行时候会自动添加一个“-”符号来连接跨行的单词. 此外,英文单词拼写校验的功能也是这样添加. 问题如图所示: 解决方法: 打开安装程序“setup.exe”——点击“添加或删 ...

  10. c#实现验证码功能(多种模式下分别实现验证功能)详细,带注释

    网上找了很多验证相关的代码,发现有很多瑕疵.现在本人整理测试了一个实现验证码功能的代码,里面有纯数字,纯英文,英文和数字混合等三种模式.并且在必要地方都已经备有注释,希望可以帮到那些需要的人. 验证码 ...