Activiti6.0教程 28张表解析 (三)
使用Activit的朋友都知道Activiti对应的有28张表,今天我们就来说下Activit中28张表对应的含义是什么? 如何创建表?在Activiti中创建表有三种方式,我们依次来看下:一、通过硬编码的形式直接指定// 创建一个流程成引擎对像 ProcessEngineConfiguration processEngineConfiguration = ProcessEngineConfiguration .createStandaloneInMemProcessEngineConfiguration(); // 设置数据库连接信息 processEngineConfiguration.setJdbcDriver("com.mysql.jdbc.Driver"); processEngineConfiguration.setJdbcUrl("jdbc:mysql://localhost:3306/db_activiti"); processEngineConfiguration.setJdbcUsername("root"); processEngineConfiguration.setJdbcPassword(""); processEngineConfiguration.setDatabaseType("mysql"); processEngineConfiguration.setDatabaseSchemaUpdate("update"); // 设置自动创建表 processEngineConfiguration.setDatabaseSchemaUpdate("true"); // 在创建引擎对象的时候自动创建表 ProcessEngine processEngine = processEngineConfiguration.buildProcessEngine(); 二、通过activit.cfg.xml配置文件<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd"> <bean id="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration"> <property name="jdbcUrl" value="jdbc:mysql://localhost:3306/db_activiti?characterEncoding=utf8" /> <property name="jdbcDriver" value="com.mysql.jdbc.Driver" /> <property name="jdbcUsername" value="root" /> <property name="jdbcPassword" value="" /> <property name="databaseSchemaUpdate" value="true" /> <property name="databaseType" value="mysql"></property> </bean> </beans> ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine(); 三、使用配置文件,在资源目录下创建activiti-context.xml<!-- 创建流程引擎配置对象 --> <bean id="ProcessEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneInMemProcessEngineConfiguration"> <property name="jdbcDriver" value="com.mysql.jdbc.Driver"/> <property name="jdbcUrl" value="jdbc:mysql://localhost:3306/db_activiti" /> <property name="jdbcUsername" value="root" /> <property name="jdbcPassword" value="" /> <property name="databaseSchemaUpdate" value="true" /> </bean> 代码里边读取加载配置文件 String resource = "activiti-context.xml"; String beanName = "ProcessEngineConfiguration"; ProcessEngineConfiguration cf = ProcessEngineConfiguration.createProcessEngineConfigurationFromResource(resource,beanName); ProcessEngine processEngine = cf.buildProcessEngine(); 以上就是创建表的三种方式,接下来我们看创建好的表都有哪些? 先上一张图,后面详细说。 Activiti中表的详细介绍?通用数据表通用数据表用于存放一些通用的数据,这些表本身不关心特定的流程或者业务,只用于其存放这些业务或者流程所使用的特定的资源,它们可以独立存在于流程引擎或者应用系统当中,其他的数据表也可以使用这些表的数据,它们都是以ACT_GE开头,GE的单词是general前两个字母的缩写。 ACT_GE_BYTEARRAY? ? 用于保存与流程引擎相关的资源,只要调用了Activit存储服务的API,其提供的资源均会转换成byte数组并保存到这个表中。资源表设计了一个byte字段,用来保存资源的内容,因此理论上可以保存任何资源类型(文件,或者其他来源的输入流)。一般情况下,Activit使用这个表来保存字符串、流程文件的内容和流程图片内容等。 ACT_GE_BYTEARRAY
属性表ACT_GE_PROPERTYActivit将全部的属性抽象为 key-value对,每个属性都有名称和值,使用ACT_GE_PROPERTY来保存这些属性,该表的字段包含如下:
流程存储表? 流程引擎中使用存储表来保存流程定义和部署信息这类数据,存储表名称以ACT_RE开头,RE是repository单词的前两个字母,可以理解为仓库的意思 部署数据表?? ?在Activit中,一次部署可以添加多个资源,资源会被保存到资源表(ACT_GE_BYTEARRA)中,而部署信息,则保存到部署表中,部署表位ACT_RE_DEPLOYMENT,其包含以下三个字段 ACT_RE_DEPLOYMENT
以上是哪个字段除了NAME_可以不设置之外,其他字段在数据写入时必须设置值 流程定义表 Activit在部署添加资源时,如果发布部署文件是流程文件(.bpmn或者.bpmn20.xml)其除了会讲内容保存到资源表外,还会解析流程文件的内容,并形成特定的流程定义数据,写入到流程定义表中(ACT_RE_PROCDEF),ACT_RE_PROCDEF包含以下字段: ACT_RE_PROCDEF
?身份数据表Activit的整个身份模块,可以独立于流程引擎而存在,身份数据表并没有保存流程相关的数据以及关联,身份表的名称使用ACT_ID开头,ID的单词是identity的前两个字母。 用户表 流程引擎用户的信息被保护在ACT_ID_UESR表中,该表有以下几个字段 ACT_ID_UESR
用户账号(信息)表 Activit将用户,用户账号和身份信息分成三种数据,其中用户表保存用户的数据,而用户账号和用户信息则被保存到ACT_ID_INFO表中,该类有如下字段 ACT_ID_INFO
用户组表ACT_ID_GROUP
关系表ACT_ID_MEMBERSHIP
运行时数据表运行时数据表用来保存流程在运行过程中所产生的数据,例如流程实例、执行流和任务等。运行时数据表的名称以ACT_ RU开头,RU是单词runtime的前两个字母。 流程实例(执行流)表当流程启动后,会产生-一个流程实例,同时会产生相应的执行流,流程实例和执行流数据均被保存在ACT_ RU_ EXECUTION表中。如果一个流程实例只有一条执行流,那么该表中只产生一条数据,该数据既表示执行流,也表示流程实例。ACT_ RU_ EXECUTION表有以下字段。 ACT_ RU_ EXECUTION
流程任务表流程在运行过程中所产生的任务数据保存在ACT_ RU_TASK表中,任务有如下字段。 ACT_ RU_TASK
流程参数表Activiti提供了ACT_ RU_ VARIABLE表来存放流程中的参数,这类参数包括流程实例参数、执行流参数和任务参数。参数可以会有多种类型,因此该表有多个字段用来存放参数值。ACT_ RU_ VARIABLE表有以下字段。 ACT_ RU_ VARIABLE
?流程与身份关系表用户组和用户之间存在的关系,使用ACT_ ID_ MEMBERSHIP表保存。用户或者用户组与流程数据之间的关系,则使用ACT_ RU_ IDENTITYLINK表进行保存。相比于ACT_ ID _MEMBERSHIP表,ACT_ RU_ IDENTITYLINK 表的字段更多一些。 ACT_ RU_ IDENTITYLINK
工作数据表在流程执行的过程中,会有一些工作需要定时或者重复执行,这类工作数据被保存到ACT RU_ JOB表中。ACT_ RU_ JOB表有以下字段。 ACT_ RU_ JOB
事件描述表ACT_RU_EVENT_SUBSCR
历史数据表? ? ?历史数据表就像流程引擎的日志表。被操作过的流程元素,将会被记录到历史表中。历史数据表名称以ACT_ HI 开头,HI是单词history的前两个字母。 流程实例表? ? ?流程实例的历史数据会被保存到ACT_ HI_ PROCINST表中,只要流程被启动,Activiti 就会将流程实例的数据写入ACT_ HI_ PROCINST 表中。除了基本的流程字段外,与运行时数据表不同的是,历史流程实例表还会记录流程的开始活动ID、结束活动ID等信息。 ACT_HI_PROCINST
流程明细表? ? 流程明细表(ACT_ HI_ DETAIL)会记录流程执行过程中的参数或者表单数据。由于在流程执行过程中,会产生大量这类数据,因此默认情况下,Activiti 不会保存流程明细数据,除非将流程引擎的历史数据(history) 配置为full。流程的历史明细数据表与运行时参数表的设计类似. ? ? 当流程到达某个任务节点时,就会向历史任务表(ACT_ HI _TASKINST)中写入历史任务数据。历史任务表与运行时的任务表设计类似,在运行时任务表的基础上,额外提供了任务开始时间(START _TIME_ )、结束时间(END_ TIME_ )和删除原因(DELETE_ REASON_ )三个字段。其中开始时间和结束时间字段类型均为datetime,如果任务被正常完成,那么删除原因字段值为completed。 ? ? ?历史行为表(ACT_ HI_ ACTINST)会记录每一个流程活动的实例,- 一个流程活动将会被记录为一条数据。例如有一个流程,开始事件、用户任务和结束事件各有一个,当流程结束后,就会产生3条历史行为数据。历史行为表有如下字段。 ACT_HI_ACTINS
ACT_?HI?ATTACHMENT
?ACT_?HI_?COMMENT表实际不只保存评论数据,它还会保存某些事件数据,但它的表名.为COMMENT,因此更倾向把它叫作评论表,该表有如下字段。 ACT_?HI_?COMMENT
??????虽然附件表和评论表的命名遵守历史数据表的命名规范(以ACT_HI开头),但是可以调用其他服务组件的API?来往这两个表中写入数据,以笔者的理解,历史数据表实际上保存的是那种-经写入,就很少会发生变化(结构性变化)的数据。
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |