Activiti数据库表结构与核心对象详解

需积分: 1 0 下载量 154 浏览量 更新于2024-07-20 收藏 295KB DOCX 举报
Activiti是一款开源的工作流引擎,用于管理和执行业务流程。本文档深入探讨了Activiti数据库表结构和核心对象的关系,旨在帮助用户更好地理解其内部运作机制。该系统基于MyBatis SQL映射器设计,将数据存储在23张默认以“ACT_”前缀命名的表中,每个表名的后两位字母指示表的功能类别。 1. **通用数据(ACT_GE_)**: 这类表包括ACT_GE_BYTEARRAY和ACT_GE_PROPERTY,主要用于存储通用的数据,如字节数组和流程属性。 2. **历史数据(ACT_HI_)**: 这些表如ACT_HI_ACTINST、ACT_HI_ATTACHMENT、ACT_HI_COMMENT等,保存流程执行的历史记录,如流程实例、附件、评论和详细信息。当历史记录级别设置为“none”时,可以选择不使用这类表。 3. **身份管理(ACT_ID_)**: 包括ACT_ID_GROUP(用户组)、ACT_ID_INFO(用户元数据)、ACT_ID_MEMBERSHIP(用户与组的关系)和ACT_ID_USER(用户信息),这些表用于存储用户和组织结构,如果已集成其他系统,这部分可能不再使用。 4. **仓库(ACT_RE_)**: ACT_RE_DEPLOYMENT用于存储部署的流程定义,ACT_RE_MODEL保存流程模型的信息,ACT_RE_PROCDEF则记录流程定义的具体内容。 5. **运行时数据(ACT_RU_)**: 这类表如ACT_RU_PROCINST、ACT_RU_TASKINST和ACT_RU_VARINST,存储流程实例、任务实例和变量的实时数据。Activiti仅保留流程执行期间的运行时数据,流程结束后会清理这些临时数据,以保持数据库轻量级和高效性能。 理解这些数据表结构对开发人员至关重要,它有助于优化数据库操作、设计查询策略和管理数据存储,确保 Activiti 的顺畅运行。同时,熟悉表与核心对象的关联也有助于故障排查和数据分析。随着业务流程的不断变化和发展,了解这些表结构的变化历史可以帮助开发者追踪和适应新版本的升级。