通用数据表
通用数据表用于存放一些通用的数据,这些表本身不关心特定的流程或者业务,只用于存放这些业务或者流程所使用的特定的资源,它们可以独立存在于流程引擎或者应用系统当中,其他的数据表也可以使用这些表的数据,它们都是以ACT_GE开头,GE的单词是general前两个字母缩写。
ACT_GE_BYTEARRAY(资源表)
用于保存与流程引擎相关的资源,只要调用了Activiti存储服务的API,其提供的资源均会转换成byte数组并保存到这个表中。资源表设计了一个byte字段,用来保存资源的内容,因此理论上可以保存任何资源类型(文件,或者其他来源的输入流)。一般情况下,Activiti使用这个表来保存字符串、流程文件的内容和流程图片内容等。
字段名 | 数据类型 | 备注 |
---|
ID_ | varchar(64) | 数据表的主键,Activit有自己的主键生成策略,每个数据表的ID_字段值,在整个流程中是唯一的 |
REV_ | int | 数据版本,Activit为一些有可能频繁修改的数据表加入该字段,用来标识该数据被操作的次数。 |
NAME_ | varchar(255) | 资源名称 |
DEPLOYMENT_ID_ | varchar(64) | 一次部署可以添加多个资源,该字段与部署表ACT_RE_DEPLOYMENT的主键关联 |
BYTES_ | longblob | 资源内容,最大可存储4GB的数据 |
GENERATED_ | tinyint | 由Activit自动产生的数据,0表示false,1表示true |
ACT_GE_PROPERTY(属性表)
Activiti将全部的属性抽象为key-value对,每个属性都有名称和值,使用ACT_GE_PROPERTY来保存这些属性。
字段名 | 数据类型 | 备注 |
---|
NAME_ | varchar(64) | 属性名称 |
VALUE_ | varchar(300) | 属性值 |
REV_ | int | 数据的版本号 |
流程存储表
流程引擎中使用存储表来保存流程定义和部署信息这类数据,存储表名称以ACT_RE开头,RE是repository单词的前两个字母缩写,可以理解为仓库的意思。
ACT_RE_DEPLOYMENT(部署数据表)
在Activiti中,一次部署可以添加多个资源,资源会被保存到资源表(ACT_GE_BYTEARRA)中,而部署信息,则保存在部署表中。
字段名 | 数据类型 | 备注 |
---|
ID_ | varchar(64) | 主键 |
NAME_ | varchar(255) | 部署名称 |
DEPLOY_TIME_ | timestamp | 部署时间 |
ACT_RE_PROCDEF(流程定义表)
Activit在部署添加资源时,如果发布部署文件是流程文件(.bpmn或者.bpmn20.xml)其除了会将内容保存到资源表外,还会解析流程文件的内容,并形成特定的流程定义数据,写入到流程定义表中。
字段名 | 数据类型 | 备注 |
---|
ID_ | varchar(64) | 主键,与其他数据表不同的是,ACT_RE_PROCDEF表的主键是组合主键,一般使用一定的规则来产生主键 |
REV_ | int | 数据版本号 |
CATEGORY_ | varchar(255) | 流程定义分类 |
NAME_ | varchar(255) | 流程定义名称 |
KEY_ | varchar(255) | 流程定义的KEY |
VERSION_ | int | 流程定义的版本 |
DEPLOYMENT_ID_ | varchar(64) | 流程定义的对应的资源名称,一般为流程文件的相对路径 |
RESOURCE_NAME_ | varchar(4000) | 流程定义的对应的资源名称 |
DGRM_RERSOURCE_NAME_ | varchar(4000) | 流程定义的对应流程图的资源名称 |
HAS_START_FORM_KEY_ | tinyint | 流程文件是否有开始表单,可以在时间中使用activiti:formKey属性来配置开始表单 |
SUSPENSION_STATE_ | int | 表示流程定义的状态是激活还是终止,如果是终止,那么将不能启动流程 |
身份数据表
ACT_ID_UESR(用户表)
字段名 | 数据类型 | 备注 |
---|
ID_ | varchar(64) | 主键 |
REV_ | int | 数据版本号 |
FIRST_ | varchar(255) | 名字的名称 |
LAST_ | varchar(255) | 名字的姓氏 |
EMAIL_ | varchar(255) | 用户邮箱 |
PWD_ | varchar(255) | 用户密码 |
PICTURE_ID_ | varchar(64) | 用户图片,对应资源表的数据ID |
ACT_ID_INFO(用户账号信息表)
字段名 | 数据类型 | 备注 |
---|
ID_ | varchar(64) | 主键 |
REV_ | int | 数据版本号 |
USER_ID_ | varchar(64) | 对应用户表的数据ID |
TYPE_ | varchar(64) | 信息类型,当前可以设置用户的帐号(account)、用户信息(userinfo)和NULL三种值 |
KEY_ | varchar(255) | 数据的键 |
VALUE_ | varchar(255) | 数据的值 |
PASSWORD_ | longblob | 用户帐号的密码字段,不过当前Activiti并没有使用该字段 |
PARENT_ID_ | varchar(255) | 该信息的父信息ID,如果一条数据设置父信息ID,则表示该数据是用户帐号(信息)的明细数据。比如有个信息有明细,那么明细就是这个帐号的数据。 |
ACT_ID_GROUP(用户组表)
字段名 | 数据类型 | 备注 |
---|
ID_ | varchar(64) | 主键 |
REV_ | int | 数据版本号 |
NAME_ | varchar(255) | 用户组名称 |
TYPE_ | varchar(255) | 用户组类型,类型不由Activit提供,某些业务中,Activit会根据该字段进行查询。 |
ACT_ID_MEMBERSHIP(关系表)
字段名 | 数据类型 | 备注 |
---|
USER_ID_ | varchar(64) | 用户ID,不能为null |
GROUP_ID_ | varchar(64) | 用户组ID,不能为null |
运行时数据表
运行时数据表用来保存流程在运行过程中所产生的数据,例如流程实例、执行流和任务等。运行时数据表的名称以ACT_RU开头,RU是单词runtime的前两个字母缩写。
ACT_ RU_ EXECUTION(流程实例表)
字段名 | 数据类型 | 备注 |
---|
ID_ | varchar(64) | 主键 |
REV_ | int | 数据版本号 |
PROC_INST_ID_ | varchar(64) | 流程实例ID,一个流程实例有可能会产生多个执行流,该字段表示执行流所属的流程实例。 |
BUSINESS_KEY_ | varchar(255) | 启动流程时指定的业务主键。 |
PARENT_ID_ | varchar(64) | 流程实例(执行流)的ID, 一个流程实例有可能会产生执行流,新的执行流数据以该字段标识其所属的流程实例 |
PROC_DEF_ID_ | varchar(64) | 流程定义数据的ID |
SUPER_EXEC_ | varchar(64) | 父执行流的ID,一个执行流可以产生新的流程实例,该流程实例数据使用该字段标识其所属的流程实例 |
ACT_ID_ | varchar(255) | 当前执行流行为的ID, ID在流程文件中定义 |
IS_ACTIVE_ | tinyint | 该执行流是否活跃的标识 |
IS_CONCURRENT_ | tinyint | 执行流是否正在并行 |
IS_SCOPE_ | tinyint | 是否在执行流范围内 |
IS_EVENT_SCOPE_ | tinyint | 是否在事件范围内 |
SUSPENSION_STATE_ | int | 标识流程的中断状态 |
CACHED_ENT_STATE_ | int | 流程实体的缓存,取值为0~7 |
ACT_RU_TASK(流程任务表)
字段名 | 数据类型 | 备注 |
---|
ID_ | varchar(64) | 主键,由Activiti的主键生成策略产生 |
REV_ | int | 数据版本号 |
EXECUTION_ID_ | varchar(64) | 任务所处的执行流ID |
PROC_INST_ID_ | varchar(64) | 流程实例ID,一个流程实例有可能会产生多个执行流,该字段表示执行流所属的流程实例 |
PROC_DEF_ID_ | varchar(64) | 流程定义数据的ID |
NAME_ | varchar(255) | 任务名称,在流程文件中定义 |
PARENT_TASK_ID_ | varchar(64) | 父任务ID,子任务才会设置该字段的值 |
DESCRIPTION_ | varchar(4000) | 任务描述,在流程文件中配置 |
TASK_DEF_KEY_ | varchar(255) | 任务定义的ID值,在流程文件中定义 |
OWNER_ | varchar(255) | 任务拥有人,没有做外键关联 |
ASSIGNEE_ | varchar(255) | 被指派执行该任务的人,没有做外键关联 |
DELEGATION_ | varchar(64) | 任务委托状态,有等候中和已解决两种状态 |
PRIORITY_ | int(11) | 任务优先级,默认为50 |
CREATE_TIME_ | timestamp | 任务创建时间 |
DUE_DATE_ | datetime | 任务预订日期 |
ACT_RU_VARIABLE(流程参数表)
Activiti提供了ACT_ RU_ VARIABLE表来存放流程中的参数,这类参数包括流程实例参数、执行流参数和任务参数。参数可以会有多种类型,因此该表有多个字段用来存放参数值。
字段名 | 数据类型 | 备注 |
---|
ID_ | varchar(64) | 主键,由Activiti的主键生成策略产生 |
REV_ | int | 数据版本号 |
TYPE_ | varchar(255) | 参数类型,该字段值可以为boolean. bytes、serializable. date. double、 integer、jpa-entity、long、 null、 short 或string,这些字段值均为Activiti 提供,还可以通过自定义来扩展参数类型 |
NAME_ | varchar(255) | 参数名称 |
EXECUTION_ID_ | varchar(64) | 该参数对应的执行ID, 可以为null. |
PROC_INST_ID_ | varchar(64) | 流程实例ID,一个流程实例有可能会产生多个执行流,该字段表示执行流所属的流程实例 |
TASK_ID_ | varchar(64) | 如果该参数是任务参数,就需要设置任务ID |
BYTEARRAY_ID_ | varchar(64) | 如果参数值是序列化对象,那么可以将该对象作为资源保存到资源表中,该字段保存资源表中数据的ID |
DOUBLE_ | double | 参数类型为double,则值会保存到该字段中 |
LONG_ | bigint | 参数类型为long, 则值会保存到该字段中 |
TEXT_ | varchar(4000) | 用于保存文本类型的参数值 |
TEXT2_ | varchar(4000) | 与TEXT_字段一样,用于保存文本类型的参数值 |
ACT_RU_IDENTITYLINK(流程与身份关系表)
字段名 | 数据类型 | 备注 |
---|
ID_ | varchar(64) | 主键,由Activiti的主键生成策略产生 |
REV_ | int | 数据版本号 |
GROUP_ID_ | varchar(255) | 该关系数据中的用户组ID |
TYPE_ | varchar(255) | 该关系数据的类型,当前提供了3个值: assignee、 candidate和owner, 表示流程数据的指派人(组)、候选人(组)和拥有人 |
USER_ID_ | varchar(255) | 关系数据中的用户ID |
TASK_ID_ | varchar(64) | 关系数据中的任务ID. |
PROC_INST_ID_ | varchar(64) | 流程实例ID,一个流程实例有可能会产生多个执行流,该字段表示执行流所属的流程实例 |
PROC_DEF_ID_ | varchar(64) | 关系数据中的流程定义ID |
ACT_RU_JOB(工作数据表)
在流程执行的过程中,会有一些工作需要定时或者重复执行,这类工作数据被保存到ACT_RU_JOB表中。
字段名 | 数据类型 | 备注 |
---|
ID_ | varchar(64) | 主键,由Activiti的主键生成策略产生 |
REV_ | int | 数据版本号 |
TYPE_ | varchar(255) | 工作类型,值为message或者timer |
LOCK_EXP_TIME_ | timestamp(3) | 工作锁定的结束时间表示 |
LOCK_OWNER_ | varchar(255) | 工作锁定标识,默认为UUID |
EXCLUSIVE_ | tinyint(1) | 工作是否需要单独执行 |
EXECUTION_ID_ | varchar(64) | 产生工作的执行流ID |
PROCESS_INSTANCE_ID_ | varchar(64) | 产生工作的流程实例ID |
PROC_DEF_ID_ | varchar(64) | 关系数据中的流程定义ID |
RETRIES_ | int | 工作的剩余执行次数,默认值为3 |
EXCEPTION_STACK_ID_ | varchar(64) | 当任务执行抛出异常时,异常堆栈信息会被保存到资源标中,该ID为关系资源表中存储的异常堆栈信息的数据ID |
EXCEPTION_MSG_ | varchar(4000) | 异常信息 |
DUEDATE_ | timestamp(3) | 工作执行时间 |
PEPEAT_ | varchar(255) | 工作重复执行次数 |
HANDLER_TYPE_ | varchar(255) | 标识工作的处理类 |
HANDLER_CFG_ | varchar(4000) | 工作相关的数据配置 |
ACT_RU_EVENT_SUBSCR(事件描述表)
字段名 | 数据类型 | 备注 |
---|
ID_ | varchar(64) | 主键,由Activiti的主键生成策略产生 |
REV_ | int | 数据版本号 |
EVENT_TYPE_ | varchar(255) | 事件类型 |
EVENT_NAME_ | varchar(255) | 事件名称 |
EXECUTION_ID_ | varchar(64) | 事件所在的执行流ID |
PROC_INST_ID_ | varchar(64) | 事件所在的流程实例ID |
ACTIVITY_ID_ | varchar(64) | 具体事件的ID |
CONFIGURATION_ | varchar(255) | 事件的属性配置 |
CREATED_ | timestamp | 事件的创建时间 |
历史数据表
历史数据表就像流程引擎的日志表。被操作过的流程元素,将会被记录到历史表中。历史数据表名称以ACT_ HI 开头,HI是单词history的前两个字母缩写。
ACT_HI_PROCINST(流程实例表)
流程实例的历史数据会被保存到ACT_ HI_ PROCINST表中,只要流程被启动,Activiti 就会将流程实例的数据写入ACT_ HI_ PROCINST 表中。除了基本的流程字段外,与运行时数据表不同的是,历史流程实例表还会记录流程的开始活动ID、结束活动ID等信息。
字段名 | 数据类型 | 备注 |
---|
START_ACT_ID | varchar(255) | 开始活动的ID |
END_ACT_ID | varchar(255) | 流程最后一个活动的ID |
EDLETE_REASON_ | varchar(4000) | 该流程实例删除的原因 |
ACT_HI_DETAIL(流程明细表)
流程明细表(ACT_ HI_ DETAIL)会记录流程执行过程中的参数或者表单数据。由于在流程执行过程中,会产生大量这类数据,因此默认情况下,Activiti 不会保存流程明细数据,除非将流程引擎的历史数据(history) 配置为full。流程的历史明细数据表与运行时参数表的设计类似。
字段名 | 数据类型 | 备注 |
---|
ID_ | varchar(64) | 主键,由Activiti的主键生成策略产生 |
REV_ | int | 数据版本号 |
TYPE_ | varchar(255) | 参数类型,该字段值可以为boolean. bytes、serializable. date. double、 integer、jpa-entity、long、 null、 short 或string,这些字段值均为Activiti 提供,还可以通过自定义来扩展参数类型 |
NAME_ | varchar(255) | 参数名称 |
EXECUTION_ID_ | varchar(64) | 该参数对应的执行ID, 可以为null. |
PROC_INST_ID_ | varchar(64) | 流程实例ID,一个流程实例有可能会产生多个执行流,该字段表示执行流所属的流程实例 |
TASK_ID_ | varchar(64) | 如果该参数是任务参数,就需要设置任务ID |
BYTEARRAY_ID_ | varchar(64) | 如果参数值是序列化对象,那么可以将该对象作为资源保存到资源表中,该字段保存资源表中数据的ID |
DOUBLE_ | double | 参数类型为double,则值会保存到该字段中 |
LONG_ | bigint | 参数类型为long, 则值会保存到该字段中 |
TEXT_ | varchar(4000) | 用于保存文本类型的参数值 |
TEXT2_ | varchar(4000) | 与TEXT_字段一样,用于保存文本类型的参数值 |
ACT_HI_TASKINST(历史任务表)
当流程到达某个任务节点时,就会向历史任务表(ACT_HI_TASKINST)中写入历史任务数据。历史任务表与运行时的任务表设计类似,在运行时任务表的基础上,额外提供了任务开始时间(START TIME)、结束时间(END_TIME_ )和删除原因(DELETE_REASON_ )三个字段。其中开始时间和结束时间字段类型均为datetime,如果任务被正常完成,那么删除原因字段值为completed。
字段名 | 数据类型 | 备注 |
---|
ID_ | varchar(64) | 主键,由Activiti的主键生成策略产生 |
EXECUTION_ID_ | varchar(64) | 任务所处的执行流ID |
PROC_INST_ID_ | varchar(64) | 流程实例ID,一个流程实例有可能会产生多个执行流,该字段表示执行流所属的流程实例 |
PROC_DEF_ID_ | varchar(64) | 流程定义数据的ID |
NAME_ | varchar(255) | 任务名称,在流程文件中定义 |
PARENT_TASK_ID_ | varchar(64) | 父任务ID,子任务才会设置该字段的值 |
DESCRIPTION_ | varchar(4000) | 任务描述,在流程文件中配置 |
TASK_DEF_KEY_ | varchar(255) | 任务定义的ID值,在流程文件中定义 |
OWNER_ | varchar(255) | 任务拥有人,没有做外键关联 |
ASSIGNEE_ | varchar(255) | 被指派执行该任务的人,没有做外键关联 |
DELEGATION_ | varchar(64) | 任务委托状态,有等候中和已解决两种状态 |
PRIORITY_ | int(11) | 任务优先级,默认为50 |
START_TIME_ | datetime | 任务开始时间 |
END_TIME_ | datetime | 任务结束时间 |
DELETE_REASON_ | varchar(4000) | 删除原因 |
DUE_DATE_ | datetime | 任务预订日期 |
ACT_HI_ACTINST(历史行为表)
历史行为表(ACT_HI_ACTINST)会记录每一个流程活动的实例,- 一个流程活动将会被记录为一条数据。例如有一个流程,开始事件、用户任务和结束事件各有一个,当流程结束后,就会产生3条历史行为数据。
字段名 | 数据类型 | 备注 |
---|
ID_ | varchar(64) | 主键,由Activiti的主键生成策略产生 |
PROC_DEF_ID_ | varchar(64) | 流程定义数据的ID |
PROC_INST_ID_ | varchar(64) | 流程实例ID,一个流程实例有可能会产生多个执行流,该字段表示执行流所属的流程实例 |
EXECUTION_ID_ | varchar(64) | 任务所处的执行流ID |
ACT_ID_ | varchar(255) | 流程活动的ID, 在流程文件中定义 |
TASK_ID_ | varchar(64) | 如果该参数是任务参数,就需要设置任务ID |
ACT_NAME_ | varchar(255) | 活动的名称 |
ACT_TYPE_ | varchar(255) | 活动类型,例如开始事件,活动名称为startEvent |
ASSIGNEE_ | varchar(255) | 活动指派人 |
START_TIME_ | datetime | 活动开始时间,即执行流到达活动时的时间 |
END_TIME_ | datetime | 活动结束时间,即执行流离开该活动时的时间 |
DURATION_ | bigint | 活动持续时间 |
ACT_HI_ATTACHMENT(历史附件表)
字段名 | 数据类型 | 备注 |
---|
ID_ | varchar(64) | 主键,由Activiti的主键生成策略产生 |
REV_ | int | 数据版本号 |
USER_ID_ | varchar(255) | 附件对应的用户ID, 可以为null |
NAME_ | varchar(255) | 附件名称 |
DESCRIPTION_ | varchar(4000) | 附件描述 |
TYPE_ | varchar(255) | 附件类型 |
TASK_ID_ | varchar(64) | 该附件对应的任务ID |
PROC_INST_ID_ | varchar(64) | 对应的流程实例ID。➢URL_ :连接到该附件的URL |
URL_ | varchar(4000) | 连接到该附件的URL |
CONTENT_ID_ | varchar(64) | 附件内容ID,附件的内容将会被保存到资源表中,该字段记录资源数据ID |
ACT_HI_COMMENT(历史评论表)
ACT_HI_COMMENT表实际不只保存评论数据,它还会保存某些事件数据,但它的表名为COMMENT,因此更倾向把它叫作评论表。
字段名 | 数据类型 | 备注 |
---|
ID_ | varchar(64) | 主键,由Activiti的主键生成策略产生 |
TYPE_ | varchar(255) | 评论的类型,可以设置为event或者comment, 表示事件记录数据或者评论数据 |
TIME_ | datetime | 数据产生的时间 |
USER_ID_ | varchar(255) | 产生评论数据的用户ID |
TASK_ID_ | varchar(64) | 该评论数据的任务ID |
PROC_INST_ID_ | varchar(64) | 数据对应的流程实例ID |
ACTION_ | varchar(255) | 该评论数据的操作标识 |
MESSAGE_ | varchar(255) | 该评论数据的信息 |
FULL_MSG_ | longblob | 该字段同样记录评论数据的信息 |