乐趣区

关于workflow:Flowable-79-张表都是干嘛的

@[toc]
当咱们应用 Flowable 流程引擎的时候,尽管咱们应用的是各种 API,然而小伙伴们都晓得,这些 API 实质上操作的都是底层的数据表,Flowable 默认一共生成了 79 张数据表,理解这些数据表,有助于咱们更好的了解 Flowable 中的各种 API,因而明天松哥就来和大家捋一捋 Flowable 中的数据表都有哪些,以及这些表都是干嘛用的。

当初咱们基本上都是 Spring Boot 工程了,在 Spring Boot 工程中,只有咱们增加了 Flowable 的仍然,而后启动我的项目,零碎就会主动帮咱们创立 79 张表,查问 SQL 如下:

SELECT COUNT(*) TABLES, table_schema FROM information_schema.TABLES  WHERE table_schema = 'flowable02' GROUP BY table_schema;

这里显示了 82 张表,是因为我本人手动创立了三个跟用户相干的表,其余 79 张表都是 Flowable 主动创立的。

好了,接下来咱们就对这 79 张表进行一个简略的分类整理。

  1. ACT_APP_*(5)
  2. ACT_CMMN_*(12)
  3. ACT_CO_*(3)
  4. ACT_DMN_*(6)
  5. ACT_EVT_*(1)
  6. ACT_FO_*(6)
  7. ACT_GE_*(2)
  8. ACT_HI_*(10)
  9. ACT_ID_*(9)
  10. ACT_PROCDEF_*(1)
  11. ACT_RE_*(3)
  12. ACT_RU_*(13)
  13. FLW_CHANNEL_*(1)
  14. FLW_EV_*(2)
  15. FLW_EVENT_*(3)
  16. FLW_RU_*(2)

* 是通配符,前面的数字示意这种类型的表有多少个。

大抵看一下,其实还是有很多法则的。

最显著的法则就表名通过两个 _ 隔开成了三局部,接下来咱们就以此为线索,一部分一部分来讲。

1. 表名前缀

首先搭建看这个表的前缀,分了两种:

  • ACT_
  • FLW_

松哥在之前的文章中曾经和大家介绍过了,Flowable 是基于 Activiti 开发进去的流程引擎,所以咱们在很多中央都还能看到 Activiti 的影子,这个表名中 ACT_ 就是 Activiti。

具体来说,与 Flowable 开源代码库相干的数据库表名以 ACT_ 结尾。特定于 Flowable Work 或 Engage 的数据库表以 FLW_ 前缀结尾。

2. 表名两头局部

紧跟着 ACT_ 或者 FLW_ 前面的内容,基本上也都是简称,例如:

  • APP 示意这都是跟应用程序相干的表。
  • CMMN 示意这都是跟 CMMN 协定相干的表。
  • CO(CONTENT)示意这都是跟内容引擎相干的表。
  • DMN 示意这都是跟 DMN 协定相干的表。
  • EVT(EVENT)示意这都是跟事件相干的表。
  • FO(FORM)示意这都是跟表单相干的表。
  • GE(GENERAL)示意这都是通用表,实用于各种用例的。
  • HI(HISTORY)这些是蕴含历史数据的表。当从运行时表中删除数据时,历史表依然蕴含这些已实现实例的所有信息。
  • ID(IDENTITY)示意这都是跟用户身份认证相干的表。
  • PROCDEF(PROCESSDEFINE)示意这都是跟记录流程定义相干的表。
  • RE(REPOSITORY)示意这都是跟流程的定义、流程的资源等等蕴含了动态信息相干的表。
  • RU(RUNTIME)代表运行时,这些是蕴含尚未实现的流程、案例等的运行时数据的运行时表。Flowable 仅在执行期间存储运行时数据,并在实例完结后删除记录,这使运行时表放弃小而快。
  • CHANNEL 示意这都是跟泳道相干的表。
  • EV 示意这个是跟 FLW_ 搭配的,在这里仿佛并没有一个明确的含意,相干的表也都是跟 Liquibase 相干的表。
  • EVENT 示意这都是跟事件相干的表。

把这些简称的单词搞明确了,接下来的就容易看懂每一个表的含意了。

表名是由三局部形成的,咱们当初曾经剖析了前两局部了,接下来咱们来看第三局部。

3. 表名后缀

表名的后缀,有一些是通用的后缀名词,咱们先来看下。

  • DATABASECHANGELOG:表名中蕴含这个单词的,示意这个表是 Liquibase 执行的记录,Liquibase 是一个数据库脚本治理的工具,有点像 flyway,松哥之前写过 flyway 的文章,我这里就不啰嗦了。蕴含 DATABASECHANGELOG 后缀的表一共是 6 张。
  • DATABASECHANGELOGLOCK:表名中蕴含这个单词的,示意这个表记录 Liquibase 执行锁的,用以确保一次只运行一个 Liquibase 实例,蕴含 DATABASECHANGELOGLOCK 后缀的表也是 6 张。

这两个加起来就 12 张表了,一共 79 张,当初还剩 67 张,咱们来具体看下。

在前面的介绍中,但凡波及到 DATABASECHANGELOG 和 DATABASECHANGELOGLOCK 的表,我就间接省略了。

3.1 ACT_APP_*

ACT_APP_* 结尾的表负责利用引擎存储和利用部署定义。相干的表一共是五张,如下:

ACT_APP_APPDEF

应用程序模型产生利用程序定义。此定义,如流程 / 案例 / 等。是胜利部署到利用引擎的利用模型的示意。

ACT_APP_DEPLOYMENT

当通过利用引擎部署利用模型时,会存储一条记录以保留此部署。部署的理论内容被存储在 ACT_APP_DEPLOYMENT_RESOURCE 表中,并从该表中援用。

ACT_APP_DEPLOYMENT_RESOURCE

此表蕴含形成应用程序部署的理论资源(存储为字节)。当引擎须要理论模型时,将从该表中获取资源。

3.2 ACT_CMMN_*

Flowable CMMN Engine 的数据库名称都以 ACT_CMMN_ 结尾。这里波及到一个货色就是 CMMN,CMMN 与 BPMN 协定统一,也是一种流程内容的标准,CMMN 这类表个别用于存储解决 BPMN 所不能实用的业务场景数据,CMMN 通常与 BPMN 搭配应用,不过只有合乎 CMMN 标准的模型数据才会应用这类表。

这里波及到的相干表一共是 12 张,如下:

  • ACT_CMMN_CASEDEF
  • ACT_CMMN_DEPLOYMENT
  • ACT_CMMN_DEPLOYMENT_RESOURCE

这三个都是没有附加前缀的表,次要定义了动态信息,例如 case 的定义和部署和以及相干的资源等。

接下来这些以 ACT_CMMN_HI_ 结尾的表代表历史数据,例如过来的案例实例、打算我的项目等。

ACT_CMMN_HI_CASE_INST

此表记录由 CMMN 引擎启动的每个案例实例的数据。

ACT_CMMN_HI_MIL_INST

此表记录了在案例实例中达到的每个里程碑的数据。

ACT_CMMN_HI_PLAN_ITEM_INST

此表记录了作为案例实例执行的一部分创立的每个打算项实例的数据。

接下来以 ACT_CMMN_RU_ 开始的表代表运行时的数据,这些数据蕴含案例实例、打算项等的运行时数据。Flowable 仅在案例实例执行期间存储运行时数据,并在案例实例完结时删除记录,这使运行时表放弃小且查问速度快。

ACT_CMMN_RU_CASE_INST

此表蕴含每个已启动但尚未实现的案例实例的条目。

ACT_CMMN_RU_MIL_INST

此表蕴含作为运行案例实例的一部分达到的每个里程碑的条目。

ACT_CMMN_RU_PLAN_ITEM_INST

案例实例执行由案例定义中定义的打算项的多个实例组成,此表蕴含在案例实例执行期间创立的每个实例的条目。

ACT_CMMN_RU_SENTRY_PART_INST

打算我的项目实例能够有守卫状态转换的哨兵,这样的哨兵在状态扭转之前能够蕴含多个局部,这个表就是专门用来存储这种哨兵。

3.3 ACT_DMN_*

Flowable DMN 的数据库名称都以 ACT_DMN_ 结尾,这里波及到的表一共是 6 张:

  • ACT_DMN_DEPLOYMENT
  • ACT_DMN_DEPLOYMENT_RESOURCE

这两个是就不须要我多说了吧,跟后面的都一样,只不过这里部署的是 DMN。

ACT_DMN_DECISION

此表蕴含已部署决策表的元数据,并与来自其余引擎的定义绝对应。

ACT_DMN_HI_DECISION_EXECUTION

此表蕴含无关 DMN 决策表执行的审计信息。

3.4 ACT_RU_*

ACT_RU_ 结尾的表都是和流程引擎运行时信息相干的一些表。波及到的表一共有 13 张:

ACT_RU_ACTINST

流程实例中的每个流动在此表中都有一行来批示流动的以后状态。

  • ACT_RU_JOB
  • ACT_RU_TIMER_JOB
  • ACT_RU_SUSPENDED_JOB
  • ACT_RU_EXTERNAL_JOB
  • ACT_RU_HISTORY_JOB
  • ACT_RU_DEADLETTER_JOB

Flowable 引擎应用作业表来实现异步逻辑、计时器或历史解决。这些表存储每个作业所需的数据。

ACT_RU_ENTITYLINK

此表存储无关实例的父子关系的信息。例如,如果流程实例启动子案例实例,则此关系存储在此表中。这样能够轻松查问关系。

ACT_RU_EVENT_SUBSCR

当流程定义应用事件(信号 / 音讯 / 等或启动 / 两头 / 边界)时,引擎将对该表的援用存储在该表中。这简化了查问哪些实例正在期待某种类型的事件。

ACT_RU_EXECUTION

存储流程实例和指向流程实例以后状态的指针(称为执行)。

ACT_RU_IDENTITYLINK

此表存储无关用户或组的数据及其与(流程 / 案例 / 等)实例相干的角色。该表也被其余须要身份链接的引擎应用。

ACT_RU_TASK

此表蕴含正在运行的实例的每个未实现用户工作的条目。而后在查问用户的工作列表时应用此表。CMMN 引擎也应用此表。

ACT_RU_VARIABLE

此表存储与实例相干的变量。CMMN 引擎也应用此表。

3.5 ACT_HI_*

ACT_HI_* 结尾的表蕴含正在运行和已实现的实例的历史数据,这些表的名称遵循其运行时对应的名称,这里一共波及到 10 张表:

ACT_HI_ACTINST

历史流动信息。这里记录流程流转过的所有节点,与 ACT_HI_TASKINST 不同的是,ACT_HI_TASKINST 只记录 Task 内容。

ACT_HI_ATTACHMENT

历史附件表。

ACT_HI_COMMENT

流程的历史评论表。

ACT_HI_DETAIL

历史详情表:流程中产生的变量具体,包含管制流程流转的变量,业务表单中填写的流程须要用到的变量等。

ACT_HI_ENTITYLINK

历史参加的人员表。

ACT_HI_IDENTITYLINK

工作参与者数据表,次要存储历史节点参与者的信息,可能是 Group 也可能是 User。

ACT_HI_PROCINST

保留每一个历史流程,创立时就生成,一条流程实例对应一个记录。

ACT_HI_TASKINST

记录每一个历史节点,一个 Task 对应一个记录。

ACT_HI_TSK_LOG

每一次执行可能会带上数据,存在这里。

ACT_HI_VARINST

流程历史变量表。

3.6 ACT_ID_*

ACT_ID_* 结尾的都是和用户身份相干的表,一共是有 9 张表:

ACT_ID_BYTEARRAY

这是用户组的部署内容。

ACT_ID_GROUP

这是用户组的表。

ACT_ID_INFO

这是所有的用户的信息,账号密码。

ACT_ID_MEMBERSHIP

用户和用户组的关联表。

ACT_ID_PRIV

权限表。

ACT_ID_PRIV_MAPPING

用户、用户组以及权限之间的关联表。

ACT_ID_PROPERTY

用户的变量表。

ACT_ID_TOKEN

用户拜访记录表。

ACT_ID_USER

用户表。

3.7 ACT_FO_FORM_*

ACT_FO_FORM_ 结尾的表存储表单引擎和围绕表单模型和这些表单的实例数据。

ACT_FO_FORM_DEFINITION

表单定义表。

ACT_FO_FORM_DEPLOYMENT

表单部署表。

ACT_FO_FORM_INSTANCE

表单实例表。

ACT_FO_FORM_RESOURCE

表单源数据表。

3.8 ACT_GE_*

ACT_GE_ 结尾的表示意一些通用信息表,波及到的表一共是两个。

ACT_GE_BYTEARRAY

存储每个流程的部署记录,bytes_ 字段中保留流程的具体内容。

ACT_GE_PROPERTY

存储 Flowable 本身的一些变量,次要是版本号。

3.9 ACT_RE_*

ACT_RE_ 结尾的表示意这些表都是跟流程的定义、流程的资源等等蕴含了动态信息相干的表。

ACT_RE_DEPLOYMENT

流程部署记录,每次服务重启会部署一次,这里会新增一条记录。

ACT_RE_MODEL

创立模型时,额定定义的一些模型相干信息,存在这张表,默认不保留。

ACT_RE_PROCDEF

记录流程的变更,流程每变更一次存一条记录,version_ 字段加 1。

3.10 FLW_EVENT_*

FLW_EVENT_DEFINITION

已部署事件定义的元数据。

FLW_EVENT_DEPLOYMENT

已部署事件部署元数据。

FLW_EVENT_RESOURCE

事件所需资源。

3.11 其余表

还剩一些规定不太显著的表,如下:

FLW_RU_BATCH
FLW_RU_BATCH_PART

这两个是批量迁徙流程时应用。

ACT_PROCDEF_INFO

流程定义信息,对流程的阐明。

ACT_CO_CONTENT_ITEM

每项内容在此表中都有个条目。

ACT_EVT_LOG

Flowable 引入了事件日志机制,默认会在数据库中创立 ACT_EVT_LOG 表保留事件日志,如果不应用事件日志,则能够删除这个表。

FLW_CHANNEL_DEFINITION

泳池管道定义表。

好啦,Flowable 中的表构造就和小伙伴们介绍结束啦~大家能够珍藏本文,在须要的时候作为一个参考~

退出移动版