Activiti数据库表结构详解

需积分: 23 6 下载量 116 浏览量 更新于2024-07-20 收藏 89KB DOCX 举报
"Activiti数据表结构" Activiti是一款开源的工作流和业务自动化引擎,它能够帮助开发者在应用程序中实现复杂的业务流程管理。在深入理解Activiti的使用之前,了解其数据表结构至关重要,因为这将直接影响到流程的部署、运行和历史记录的管理。 1. Activiti数据库表结构概述 Activiti的所有数据表都以"ACT_"作为前缀,便于识别和管理。表名的后两个字母代表了表的主要用途: - ACT_GE_*:通用数据,用于不同场景。 - ACT_HI_*:历史数据,记录流程实例、任务和变量的历史信息。 - ACT_ID_*:身份数据,包括用户、组和它们的关系。如果Activiti与其他系统集成,可直接利用已有用户和组信息。 - ACT_RE_*:仓库数据,存储静态信息,如流程定义和资源。 - ACT_RU_*:运行时数据,保存流程实例在执行过程中的状态。 2. 数据表详细说明 - ACT_GE_BYTEARRAY:通用字节数组。用于存储流程定义文件(如XML和图片)以及可序列化的变量。需要注意的是,部署时应避免包含无关文件,以免引起错误。 - ACT_GE_PROPERTY:系统属性表。存储流程引擎级别的配置和属性,如版本信息。 - ACT_ID_USER:用户表,记录用户信息。 - ACT_ID_GROUP:组表,定义用户组。 - ACT_ID_MEMBERSHIP:成员关系表,关联用户和组。 - ACT_RE_PROCDEF:流程定义表,存储流程的元数据,包括流程图、版本和关键信息。 - ACT_RE_DEPLOYMENT:部署表,记录流程定义的部署信息。 - ACT_RU_EXECUTION:运行时执行实例表,记录流程实例的状态。 - ACT_RU_TASK:运行时任务表,存储当前活动任务的信息。 - ACT_RU_VARIABLE:运行时变量表,保存流程实例中的变量值。 - ACT_RU_IDENTITYLINK:运行时身份链接表,关联任务和用户/组。 - ACT_RU_EVENT_SUBSCR:运行时事件订阅表,用于监听和处理流程事件。 3. 历史记录级别 Activiti提供了四种历史记录级别,包括none、activity、audit和full。none级别不保存任何历史数据,activity级别保存基本的流程实例和任务信息,audit是默认级别,保存更多详细信息,full则保存最完整的记录,包括流程变量。选择不同的级别可以根据实际需求平衡性能和记录详细度。 了解Activiti的数据表结构有助于优化流程管理,确保流程引擎的高效运行,并能够正确地记录和追溯流程历史。在实际应用中,应根据业务需求配置合适的历史记录级别,并谨慎处理部署资源,以保证系统的稳定性和性能。
2017-11-08 上传
1. 初识Activiti 1.1. 工作流与工作流引擎 工作流(workflow)就是工作流程的计算模型,即将工作流程中的工作如何前后组织在一起的逻辑和规则在计算机中以恰当的模型进行表示并对其实施计算。它主要解决的是“使在多个参与者之间按照某种预定义的规则传递文档、信息或任务的过程自动进行,从而实现某个预期的业务目标,或者促使此目标的实现”。(我的理解就是:将部分或者全部的工作流程、逻辑让计算机帮你来处理,实现自动化) 所谓工作流引擎是指workflow作为应用系统的一部分,并为之提供对各应用系统有决定作用的根据角色、分工和条件的不同决定信息传递路由、内容等级等核心解决方案。 例如开发一个系统最关键的部分不是系统的界面,也不是和数据库之间的信息交换,而是如何根据业务逻辑开发出符合实际需要的程序逻辑并确保其稳定性、易维护性和弹性。 比如你的系统中有一个任务流程,一般情况下这个任务的代码逻辑、流程你都要自己来编写。实现它是没有问题的。但是谁能保证逻辑编写的毫无纰漏?经过无数次的测试与改进,这个流程没有任何漏洞也是可以实现的,但是明显就会拖慢整个项目的进度。 工作流引擎解决的就是这个问题:如果应用程序缺乏强大的逻辑层,势必变得容易出错(信息的路由错误、死循环等等)。 1.2. BPMN2.0规范 BPMN(Business Process Model and Notation)--业务流程模型与符号。 BPMN是一套流程建模的标准,主要目标是被所有业务用户容易理解的符号,支持从创建流程轮廓的业务分析到这些流程的最终实现,知道最终用户的管理监控。 通俗一点其实就是一套规范,画流程模型的规范。流程模型包括:流程图、协作图、编排图、会话图。详细信息请google。 1.3. Activiti概述 1.3.1. Activiti由来 学习过Activiti的朋友都知道,Activiti的创始人也就是JBPM(也是一个优秀的BPM引擎)的创始人,从Jboss离职后开发了一个新的BPM引擎:Activiti。所以,Activiti有很多地方都有JBPM的影子。所以,据说学习过JBPM的朋友学起Activiti来非常顺手。 由于本人之前没有工作流及JBPM的相关基础,刚开始学习Activiti的时候可以说是无比痛苦的,根本不知道从何下手,这里也建议大家先进行工作流及BPMN2.0规范的学习,有了一定的基础后,再着手学习Activiti。 1.3.2. Activiti简介 Activiti是一个开源的工作流引擎,它实现了BPMN 2.0规范,可以发布设计好的流程定义,并通过api进行流程调度。 Activiti 作为一个遵从 Apache 许可的工作流和业务流程管理开源平台,其核心是基于 Java 的超快速、超稳定的 BPMN2.0 流程引擎,强调流程服务的可嵌入性和可扩展性,同时更加强调面向业务人员。 Activiti 流程引擎重点关注在系统开发的易用性和轻量性上。每一项 BPM 业务功能 Activiti 流程引擎都以服务的形式提供给开发人员。通过使用这些服务,开发人员能够构建出功能丰富、轻便且高效的 BPM 应用程序。 1.4. 文档说明 以上部分对工作流、BPMN、Activiti的概念做了一个简单的介绍,目的是了解Activiti究竟是什么,能做些什么…及在学习Activiti之前需要了解的知识与技术。其中大部分文字来自Copy网上的各种资料与文档,通过总结而来的。具体的更详细的内容需自己google,参考一些官方的文档与手册。 本文档之后内容如下: 1) 下载与使用 2) 核心组件与说明 3) 入门示例 4) Eclipse中的Activiti插件的使用 本文档旨在为初学Activiti的朋友提供入门级别的参考,不会对其原理及其结构进行深层次的探究(更多是因为目前自身理解还不是很透彻),只是为大家理清思路,方便以后更深层次的学习。本文档还有一个重要的特点,那就是根据自己看官方手册的经验,教大家如何看手册从而更有效率!由于是初学,很多术语或解释难免理解有偏差,所以一定要看官方提供的文档与手册,那才是学习的最佳途径! 2. 开始学习 2.1. 必要的准备 2.1.1. 下载与了解目录 下载Activiti:下载路径,也就是官方网站的地址:http://activiti.org/download.html。下载后解压(我所使用的是5.12版本的,Activiti更新速度飞快,几乎每两个月就会有一个更新的小版本),看到如下目录: 1) database:里面存放的是Activiti使用到的数据库信息的sql文件,它支持的数据库类型如下图,使用时只需执行你自己的数据库类型