activiti工作流对象关系及表结构

上传人:第*** 文档编号:31071532 上传时间:2018-02-04 格式:DOCX 页数:9 大小:240.03KB
返回 下载 相关 举报
activiti工作流对象关系及表结构_第1页
第1页 / 共9页
activiti工作流对象关系及表结构_第2页
第2页 / 共9页
activiti工作流对象关系及表结构_第3页
第3页 / 共9页
activiti工作流对象关系及表结构_第4页
第4页 / 共9页
activiti工作流对象关系及表结构_第5页
第5页 / 共9页
点击查看更多>>
资源描述

《activiti工作流对象关系及表结构》由会员分享,可在线阅读,更多相关《activiti工作流对象关系及表结构(9页珍藏版)》请在金锄头文库上搜索。

1、Activiti 数据表结构和核心对象关系西安创富电子科技有限公司二一三年九月西安创富电子科技有限公司 Activiti 数据表结构和核心对象关系版本历史日期 版本 说明(文档修改描述) 作者 审核人2013.9 文档初稿 焦剑波西安创富电子科技有限公司 Activiti 数据表结构和核心对象关系目录1 ACTIVITI 数据库表结构 -41.1 数据库表名说明 -41.2 数据库表结构 -42 ACTIVITI 中主要对象的关系 -16西安创富电子科技有限公司 Activiti 数据表结构和核心对象关系1 Activiti 数据库表结构1.1 数据库表名说明Activiti 工作流总共包含

2、23 张数据表,所有的表名默认以“ACT_”开头。并且表名的第二部分用两个字母表明表的用例,而这个用例也基本上跟Service API 匹配。 ACT_GE_* : “GE”代表“General”(通用),用在各种情况下; ACT_HI_* : “HI”代表“History”(历史),这些表中保存的都是历史数据,比如执行过的流程实例、变量、任务,等等。当系统中配置 history的信息记录级别为“none”时,这一类表也可以不用; ACT_ID_* : “ID”代表“Identity”(身份),这些表中保存的都身份信息,如用户和组以及两者之间的关系。如果 Activiti 被集成在某一系统当中

3、的话,这些表可以不用,可以直接使用现有系统中的用户或组信息; ACT_RE_* : “RE”代表“Repository”(仓库),这些表中保存一些 静态信息,如流程定义和流程资源(如图片、规则等); ACT_RU_* : “RU”代表“Runtime”(运行时),这些表中保存一些流程实例、用户任务、变量等的运行时数据。Activiti 只保存流程实例在执行过程中的运行时数据,并且当流程结束后会立即移除这些数据,这是为了保证运行时表尽量的小并运行的足够快;1.2 数据库表结构Activiti 数据表清单:西安创富电子科技有限公司 Activiti 数据表结构和核心对象关系表名 解释ACT_GE_

4、BYTEARRAY 通用的流程定义和流程资源ACT_GE_PROPERTY 系统相关属性ACT_HI_ACTINST 历史的流程实例ACT_HI_ATTACHMENT 历史的流程附件ACT_HI_COMMENT 历史的说明性信息ACT_HI_DETAIL 历史的流程运行中的细节信息ACT_HI_IDENTITYLINK 历史的流程运行过程中用户关系ACT_HI_PROCINST 历史的流程实例ACT_HI_TASKINST 历史的任务实例ACT_HI_VARINST 历史的流程运行中的变量信息ACT_ID_GROUP 身份信息-组信息ACT_ID_INFO 身份信息-组信息ACT_ID_MEM

5、BERSHIP 身份信息-用户和组关系的中间表ACT_ID_USER 身份信息-用户信息ACT_RE_DEPLOYMENT 部署单元信息ACT_RE_MODEL 模型信息ACT_RE_PROCDEF 已部署的流程定义ACT_RU_EVENT_SUBSCR 运行时事件ACT_RU_EXECUTION 运行时流程执行实例ACT_RU_IDENTITYLINK 运行时用户关系信息ACT_RU_JOB 运行时作业ACT_RU_TASK 运行时任务ACT_RU_VARIABLE 运行时变量表2 Activiti 中主要对象的关系本节主要介绍在工作流中出现的几个对象及其之间的关系,以及在Activiti

6、中各个对象是如何关联的。在开始之前先看看下图,对整个对象结构有个了解,再结合实例详细介绍理解。西安创富电子科技有限公司 Activiti 数据表结构和核心对象关系图 1. Activiti 中几个对象之间的关系我们模拟一个请假的流程进行分析介绍,该流程主要包含以下几个步骤: 员工申请请假 部门领导审批 人事审批 员工销假ProcessInstance 对象员工开始申请请假流程,通过 runtimeService.startProcessInstance()方法启动,引擎会创建一个流程实例(ProcessInstance)。简单来说流程实例就是根据一次(一条)业务数据用流程驱动的入口,两者之间是

7、一对一的关系。流程引擎会创建一条数据到 ACT_RU_EXECUTION 表,同时也会根据 history 的级别决定是否查询相同的历史数据到 ACT_HI_PROCINST表。启动完流程之后业务和流程已经建立了关联关系,第一步结束。启动流程和业务关联区别: 对于自定义表单来说启动的时候会传入 businessKey 作为业务和流程的关联属性 对于动态表单来说不需要使用 businessKey 关联,因为所有的数据都保存在引擎的表中西安创富电子科技有限公司 Activiti 数据表结构和核心对象关系 对于外部表单来说 businessKey 是可选的,但是一般不会为空,和自定义表单类似Exec

8、ution 对象对于初学者来说,最难理解的地方就是 ProcessInstance 与 Execution 之间的关系,要分两种情况说明。Execution 的含义就是一个流程实例(ProcessInstance)具体要执行的过程对象。不过在说明之前先声明两者的对象映射关系:ProcessInstance(1) Execution(N),(其中 N = 1)。1) 值相等的情况:除了在流程中启动的子流程之外,流程启动之后在表 ACT_RU_EXECUTION 中的字段 ID_和 PROC_INST_ID_字段值是相同的。图 2. ID_和 PROC_INST_ID_相等2) 值不相等的情况:不

9、相等的情况目前只会出现在子流程中(包含:嵌套、引入),例如一个购物流程中除了下单、出库节点之外可能还有一个付款子流程,在实际企业应用中付款流程通常是作为公用的,所以使用子流程作为主流程(购物流程)的一部分。当任务到达子流程时引擎会自动创建一个付款流程,但是这个流程有一个特殊的地方,在数据库可以直观体现,如下图。图 3. ID_和 PROC_INST_ID_不相等西安创富电子科技有限公司 Activiti 数据表结构和核心对象关系上图中有两条数据,第二条数据(嵌入的子流程)的 PARENT_ID_等于第一条数据的 ID_和 PROC_INST_ID_,并且两条数据的 PROC_INST_ID_相

10、同。上图中还有一点特殊的地方,字段 IS_ACTIVE_的值分别是 0 和 1,说明正在执行子流程主流程挂起。Task 对象前面说了 ProcessInstance 和业务是一对一关联的,和业务数据最亲密;而 Task 则和用户最亲密的(UserTask),用户每天的待办事项就是一个个的Task 对象。从图 1 中看得出 Execution 和 Task 是一对一关系,Task 可以是任何类型的 Task 实现,可以是用户任务(UserTask)、Java 服务(Java ServiceTask)等,在实际流程运行中只不过面向对象不同,用户任务(UserTask)需要有人为参与完成(compl

11、ete),Java 服务需要由系统自动执行(execution)。图 4. 表 ACT_RU_TASKTask 是在流程定义中看到的最大单位,每当一个 Task 完成的时候会引擎会把当前的任务移动到历史中,然后插入下一个任务插入到表 ACT_RU_TASK 中。结合请假流程来说就是让用户点击“完成”按钮提交当前任务是的动作,引擎自动根据任务的顺序流或者排他分支判断走向。HistoryActivity(历史活动)图 5. 表 ACT_HI_ACTINST西安创富电子科技有限公司 Activiti 数据表结构和核心对象关系Activity 包含了流程中所有的活动数据,例如开始事件(图 5 表中的第 1条数据)、各种分支(排他分支、并行分支等,图 5 表中的第 2 条数据)、以及刚刚提到的 Task 执行记录(如图 5 表中的第 3、4 条数据)。有些人认为 Activity 和 Task 是多对一关系,其实不是,从上图中可以看出来根本没有 Task 相关的字段。结合请假流程来说,如 Task 中提到的当完成流程的时候所有下一步要执行的任务(包括各种分支)都会创建一个 Activity 记录到数据库中。例如领导审核节点点击“同意”按钮就会流转到人事审批节点,如果“驳回”那就流转到调整请假内容节点,每一次操作的 Task 背后实际记录更详细的活动(Activity)。

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 解决方案

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号