Activiti教程(五)activiti5初始化表和讲解表

声明:表详细数据转载自 https://blog.csdn.net/hj7jay/article/details/51302829

该博主对activiti数据模型做了很深的讲解

一.框架结构

二.初始化activit5框架的表 执行测试类里的createTables方法

package com.lpinfo.activiti.test;

import org.activiti.engine.ProcessEngine;
import org.activiti.engine.ProcessEngineConfiguration;
import org.activiti.engine.ProcessEngines;
import org.activiti.engine.repository.Deployment;
import org.junit.Test;

public class ActivitiTest {
	
	ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();

	@Test
	public void createTables(){
		ProcessEngineConfiguration processEngineConfiguration = ProcessEngineConfiguration.createStandaloneProcessEngineConfiguration();
		processEngineConfiguration.setJdbcDriver("com.mysql.jdbc.Driver");
		processEngineConfiguration.setJdbcUrl("jdbc:mysql://localhost:3306/lpinfo-activiti?useUnicode=true&characterEncoding=utf8");
		processEngineConfiguration.setJdbcUsername("root");
		processEngineConfiguration.setJdbcPassword("root");
		processEngineConfiguration.setDatabaseSchemaUpdate(ProcessEngineConfiguration.DB_SCHEMA_UPDATE_CREATE_DROP);
		processEngineConfiguration.buildProcessEngine();
	}
	/**
	 * ===配置 细信息
	 * getRepositoryService() //与流程定义和部署对象相关的Service
	 * createDeployment()  //创建一个部署对象
	 * name("helloworld入门程序")  //添加部署的名称
	 * addClasspathResource("diagrams/helloworld.bpmn") //从classpath的资源中加载,一次只能加载一个文件
	 * addClasspathResource("diagrams/helloworld.png") //从classpath的资源中加载,一次只能加载一个文件
	 * deploy() //完成部署
	 * ===操作的表
	 *  
	 * 
	 */
	@Test
	public void deploymentProcessDefinition(){
		Deployment deployment = processEngine.getRepositoryService()
						.createDeployment()
						.name("helloworld入门程序")
						.category("helloword")
						.addClasspathResource("diagrams/helloworld.bpmn")
						.addClasspathResource("diagrams/helloworld.png")
						.deploy();//完成部署
		System.out.println("部署ID:"+deployment.getId());
		System.out.println("部署类别:"+deployment.getCategory());
		System.out.println("部署名称:"+deployment.getName());
	}
	
	
}

三.框架表讲解

1.框架表截图

2.相关表讲解 

   Activiti工作流总共包含23张数据表,所有的表名默认以“ACT_”开头。

并且表名的第二部分用两个字母表明表的用例,而这个用例也基本上跟Service API匹配。

u  ACT_GE_* : “GE”代表“General”(通用),用在各种情况下;

u  ACT_HI_* : “HI”代表“History”(历史),这些表中保存的都是历史数据,比如执行过的流程实例、变量、任务,等等。Activit默认提供了4种历史级别:

Ø  none: 不保存任何历史记录,可以提高系统性能;

Ø  activity:保存所有的流程实例、任务、活动信息;

Ø  audit:也是Activiti的默认级别,保存所有的流程实例、任务、活动、表单属性;

Ø  full:最完整的历史记录,除了包含audit级别的信息之外还能保存详细,例如:流程变量。

对于几种级别根据对功能的要求选择,如果需要日后跟踪详细可以开启full。

u  ACT_ID_* : “ID”代表“Identity”(身份),这些表中保存的都是身份信息,如用户和组以及两者之间的关系。如果Activiti被集成在某一系统当中的话,这些表可以不用,可以直接使用现有系统中的用户或组信息;

u  ACT_RE_* : “RE”代表“Repository”(仓库),这些表中保存一些‘静态’信息,如流程定义和流程资源(如图片、规则等);

u  ACT_RU_* : “RU”代表“Runtime”(运行时),这些表中保存一些流程实例、用户任务、变量等的运行时数据。Activiti只保存流程实例在执行过程中的运行时数据,并且当流程结束后会立即移除这些数据,这是为了保证运行时表尽量的小并运行的足够快;
 

表名称描述
一般 数据

ACT_GE_BYTEARRAY

通用的流程定义和流程资源 

ACT_GE_PROPERTY

系统相关属性 

   
流程定义

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

运行时变量表

   
组用户

ACT_ID_GROUP

身份信息-组信息

ACT_ID_INFO

身份信息-组信息

ACT_ID_MEMBERSHIP

身份信息-用户和组关系的中间表

ACT_ID_USER

身份信息-用户信息

   
历史记录

ACT_HI_ACTINST

历史的流程实例

ACT_HI_ATTACHMENT

历史的流程附件

ACT_HI_COMMENT

历史的说明性信息

ACT_HI_DETAIL

历史的流程运行中的细节信息

ACT_HI_IDENTITYLINK

历史的流程运行过程中用户关系

ACT_HI_PROCINST

历史的流程实例

ACT_HI_TASKINST

历史的任务实例

ACT_HI_VARINST

历史的流程运行中的变量信息

   

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

3.各自表讲解

2  Activiti中主要对象的关系
本节主要介绍在工作流中出现的几个对象及其之间的关系,以及在Activiti中各个对象是如何关联的。

在开始之前先看看下图,对整个对象结构有个了解,再结合实例详细介绍理解。

图1.Activiti中几个对象之间的关系

我们模拟一个请假的流程进行分析介绍,该流程主要包含以下几个步骤:

u  员工申请请假

u  部门领导审批

u  人事审批

u  员工销假

 

ProcessInstance对象

员工开始申请请假流程,通过runtimeService.startProcessInstance()方法启动,引擎会创建一个流程实例(ProcessInstance)。

简单来说流程实例就是根据一次(一条)业务数据用流程驱动的入口,两者之间是一对一的关系。流程引擎会创建一条数据到ACT_RU_EXECUTION表,同时也会根据history的级别决定是否查询相同的历史数据到ACT_HI_PROCINST表。

启动完流程之后业务和流程已经建立了关联关系,第一步结束。

启动流程和业务关联区别:

u 对于自定义表单来说启动的时候会传入businessKey作为业务和流程的关联属性

u 对于动态表单来说不需要使用businessKey关联,因为所有的数据都保存在引擎的表中

u 对于外部表单来说businessKey是可选的,但是一般不会为空,和自定义表单类似

 

Execution对象

对于初学者来说,最难理解的地方就是ProcessInstance与Execution之间的关系,要分两种情况说明。Execution的含义就是一个流程实例(ProcessInstance)具体要执行的过程对象。

不过在说明之前先声明两者的对象映射关系:

ProcessInstance(1)→ Execution(N),(其中N>=1)。

1)  值相等的情况:

除了在流程中启动的子流程之外,流程启动之后在表ACT_RU_EXECUTION中的字段ID_和PROC_INST_ID_字段值是相同的。

图2.ID_和PROC_INST_ID_相等

2)  值不相等的情况:

不相等的情况目前只会出现在子流程中(包含:嵌套、引入),例如一个购物流程中除了下单、出库节点之外可能还有一个付款子流程,在实际企业应用中付款流程通常是作为公用的,所以使用子流程作为主流程(购物流程)的一部分。

当任务到达子流程时引擎会自动创建一个付款流程,但是这个流程有一个特殊的地方,在数据库可以直观体现,如下图。

图3.ID_和PROC_INST_ID_不相等

上图中有两条数据,第二条数据(嵌入的子流程)的PARENT_ID_等于第一条数据的ID_和PROC_INST_ID_,并且两条数据的PROC_INST_ID_相同。

上图中还有一点特殊的地方,字段IS_ACTIVE_的值分别是0和1,说明正在执行子流程主流程挂起。

 

Task对象

前面说了ProcessInstance和业务是一对一关联的,和业务数据最亲密;而Task则和用户最亲密的(UserTask),用户每天的待办事项就是一个个的Task对象。

从图1中看得出Execution和Task是一对一关系,Task可以是任何类型的Task实现,可以是用户任务(UserTask)、Java服务(JavaServiceTask)等,在实际流程运行中只不过面向对象不同,用户任务(UserTask)需要有人为参与完成(complete),Java服务需要由系统自动执行(execution)。

图4. 表ACT_RU_TASK

Task是在流程定义中看到的最大单位,每当一个Task完成的时候引擎会把当前的任务移动到历史中,然后插入下一个任务插入到表ACT_RU_TASK中。结合请假流程来说就是让用户点击“完成”按钮提交当前任务是的动作,引擎自动根据任务的顺序流或者排他分支判断走向。

 

HistoryActivity(历史活动)

图5. 表ACT_HI_ACTINST

 

Activity包含了流程中所有的活动数据,例如开始事件(图5表中的第1条数据)、各种分支(排他分支、并行分支等,图5表中的第2条数据)、以及刚刚提到的Task执行记录(如图5表中的第3、4条数据)。

有些人认为Activity和Task是多对一关系,其实不是,从上图中可以看出来根本没有Task相关的字段。

结合请假流程来说,如Task中提到的当完成流程的时候所有下一步要执行的任务(包括各种分支)都会创建一个Activity记录到数据库中。例如领导审核节点点击“同意”按钮就会流转到人事审批节点,如果“驳回”那就流转到调整请假内容节点,每一次操作的Task背后实际记录更详细的活动(Activity)。
 

1. ACT_GE_PROPERTY:流程引擎属性,存储全局属性,如流程引擎版本等。 2. ACT_GE_BYTEARRAY:字节数组,用于存储流程定义、流程实例等的二进制数据,如bpmn文件、流程图等。 3. ACT_RE_DEPLOYMENT:部署,存储每次部署的信息,如部署时间、部署人员等。 4. ACT_RE_PROCDEF:流程定义,存储流程定义的信息,如流程名称、版本、启动单等。 5. ACT_RU_EXECUTION:流程实例,存储流程实例的运行时信息,如流程实例ID、当前节点ID、变量等。 6. ACT_HI_PROCINST:历史流程实例,存储已经结束的流程实例的信息,如流程开始时间、结束时间、持续时间等。 7. ACT_HI_ACTINST:历史节点,存储流程实例中每个节点的信息,如节点类型、节点名称、开始时间、结束时间等。 8. ACT_HI_TASKINST:历史任务,存储流程实例中每个任务的信息,如任务名称、处理人、开始时间、结束时间等。 9. ACT_HI_VARINST:历史变量,存储流程实例中每个变量的信息,如变量名称、变量类型、变量值等。 10. ACT_RU_TASK:任务,存储当前流程实例中每个任务的信息,如任务名称、处理人、开始时间、结束时间等。 11. ACT_RU_IDENTITYLINK:任务参与者,存储每个任务的参与者信息,如候选人、候选组等。 12. ACT_RE_MODEL:模型,存储流程模型的信息,如模型名称、创建人、创建时间等。 13. ACT_HI_COMMENT:历史评论,存储流程实例中每个任务的评论信息,如评论人、评论时间、评论内容等。 14. ACT_ID_GROUP:用户组,存储用户组的信息,如组名称、组类型等。 15. ACT_ID_MEMBERSHIP:用户-用户组关系,存储每个用户与用户组之间的关系。 16. ACT_ID_USER:用户,存储用户的信息,如用户名、密码、邮箱等。 17. ACT_RU_EVENT_SUBSCR:事件订阅,存储每个事件订阅的信息,如事件名称、流程实例ID、执行ID等。 18. ACT_HI_ATTACHMENT:历史附件,存储每个任务的附件信息,如附件名称、附件类型、附件描述等。 19. ACT_RU_VARIABLE:变量,存储每个流程实例中的变量信息,如变量名称、变量值、变量类型等。 20. ACT_RU_JOB:定时任务,存储每个定时任务的信息,如任务名称、执行时间等。 21. ACT_RU_SUSPENDED_JOB:挂起的定时任务,存储每个被暂停的定时任务的信息。 22. ACT_HI_JOB_LOG:历史定时任务日志,存储每个定时任务的执行日志信息,如任务名称、执行时间、执行结果等。 23. ACT_RE_MODEL_BYTEARRAY:模型字节数组,存储每个模型的二进制数据。 24. ACT_RU_EVENT_SUBSCR:事件订阅,存储每个事件订阅的信息,如事件名称、流程实例ID、执行ID等。 25. ACT_HI_IDENTITYLINK:历史任务参与者,存储每个任务的参与者信息,如候选人、候选组等。 26. ACT_HI_DETAIL:历史详情,存储每个流程实例的详细历史信息,如变量修改记录、任务完成记录等。 27. ACT_RU_DEADLETTER_JOB:死信定时任务,存储每个因为异常而失败的定时任务的信息。 28. ACT_RU_SUSPENDED_JOB:挂起的定时任务,存储每个被暂停的定时任务的信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值