1、Flowable是什么?

Flowable是一个使用Java编写的轻量级业务流程引擎。Flowable流程引擎可用于部署BPMN 2.0流程定义(用于定义流程的行业XML标准), 创建这些流程定义的流程实例,进行查询,访问运行中或历史的流程实例与相关数据,等等。

简单来说:Flowable将审批节点抽象出来,那么作为使用者而言只需要通过流程设计器定义流程模板,定义动态表单,挂载表单数据,通过流程定义和流程变量启动流程实例即可。使用者不需要知道整个流程具体如何执行,只需要记住审批人是谁,审批通过没有即可。

因此:flowable流程引擎非常适用存在审批的项目上,当然审批是需要提交表单的,因此常常配合表单设计器一起使用。

2、BPMN2.0 是什么?

BPMN(Business Process Model and Notation)是一个业务流程模型标记规范,以精准的执行语义来描述元素的操作,以XML为载体,以符号为可视化业务。

目前端是通过Bpmn.js 实现 BPMN2.0规范,设计出来的流程设计器。

3、Flowable数据库表命名规则

Flowable的所有数据库表都以ACT_开头。第二部分是说明表用途的两字符标示符。服务API的命名也大略符合这个规则。

3.1 flowable提供的表

1、ACT_RE_: 'RE’代表repository。带有这个前缀的表包含“静态”信息,例如流程定义与流程资源(图片、规则等)。
2、ACT_RU_
: 'RU’代表runtime。这些表存储运行时信息,例如流程实例(process instance)、用户任务(user task)、变量(variable)、作业(job)等。Flowable只在流程实例运行中保存运行时数据,并在流程实例结束时删除记录。这样保证运行时表小和快。
3、ACT_HI_: 'HI’代表history。这些表存储历史数据,例如已完成的流程实例、变量、任务等。
4、ACT_GE_
: 通用数据。在多处使用。
5、ACT_ID_*: 表示组织信息,如用户,用户组,等等。(很少使用)

3.2、ACT_GE_*

ACT_GE_BYTEARRAY:保存流程的bpmn的xml以及流程的Image缩略图等信息

ACT_GE_PROPERTY:Flowable相关的基本信息。比如各个module使用的版本信息。

3.3、ACT_RE_*

’RE’表示repository(存储)。RepositoryService接口操做的表。带此前缀的表包含的是静态信息,如,流程定义,流程的资源(图片,规则等)

ACT_RE_DEPLOYMENT: 部署对象,存储流程名称

ACT_RE_MODEL:基于流程的模型信息,流程设计器设计流程模型保存的数据,包含:建立时间,最后更新时间,元数据(META_INFO_:以json格式保存流程定义的信息),部署ID(DEPLOYMENT_ID_)

ACT_RE_PROCDEF:流程定义表

此表和ACT_RE_DEPLOYMENT是多对一的关系,即,一个部署的bar包里可能包含多个流程定义文件,每一个流程定义文件都会有一条记录在ACT_REPROCDEF表内,每一个流程定义的数据,都会对于ACT_GE_BYTEARRAY表内的一个资源文件和PNG图片文件。

ACT_GE_BYTEARRAY的关联:是经过程序用ACT_GE_BYTEARRAY.NAME与ACT_RE_PROCDEF.NAME_完成的,在数据库表结构中没有体现

分类(CATEGORY_:流程定义的Namespace就是类别),部署ID(DEPLOYMENT_ID_),资源名称(RESOURCE_NAME_:流程bpmn文件名称),拥有开始表单标识(HAS_START_FORM_KEY_:start节点是否存在 formKey 0否 1是),挂起状态(SUSPENSION_STATE_:暂停状态 1激活 2暂停)

3.4、ACT_RU_*

RU’表示runtime。这是运行时的表存储着流程变量,用户任务,变量,职责(job)等运行时的数据。
flowable只存储实例执行期间的运行时数据,当流程实例结束时,将删除这些记录。这就保证了这些运行时的表小且快。

ACT_RU_ACTINST:运行中实例的活动表,一般是流程图中正在活动的节点,包含箭头哦

ACT_RU_DEADLETTER_JOB:当JOB执行很多次都无法执行,就会被记录在此表

ACT_RU_ENTITYLINK:还没使用到

ACT_RU_EVENT_SUBSCR:运行时的事件,包含:流程定义ID,流程实例ID,执行实例ID,节点ID,建立时间等

ACT_RU_EXECUTION:运行的实例表,包含:流程实例ID,流程定义ID,父级ID,父级的执行实例ID,节点ID,挂起状态(SUSPENSION_STATE_:1激活 2暂停),缓存状态(CACHED_ENT_STATE_:缓存的状态, 1 事件监听 2 人工任务 3 异步做业)

ACT_RU_HISTORY_JOB; 运行中的定时任务历史表

ACT_RU_IDENTITYLINK: 当前任务执行人的信息,主要存储当前节点参与者的信息,包含:用户组ID,用户ID,任务ID,流程实例ID,流程定义ID

ACT_RU_JOB:运行中的异步任务

  • 锁定过时时间(LOCK_EXP_TIME_),挂起者(LOCK_OWNER_),是否惟一(EXCLUSIVE_),执行实例ID,流程实例ID,流程定义ID,重试次数(RETRIES_),截至时间(DUEDATE_)

  • 须要启用JOB组件JobExecutor 是管理一组线程的组件,这些线程用于触发定时器(包括后续的异步消息)。在单元测试场景下,使用多线程会很笨重。

  • ManagementService.createJobQuery 用于查询,

  • ManagementService.executeJob 用于执行做业。

  • 这样做业的执行就能够在单元测试内部控制。为了不做业执行器的干扰,能够将它关闭。默认状况下, JobExecutor 在流程引擎启动时激活。
    当你不但愿 JobExecutor 随流程引擎启动时,设置:

  • 启用异步执行器 Async executor activation
    AsyncExecutor 是管理线程池的组件,这个线程池用于触发定时器与异步任务。
    默认状况下,因为历史缘由,当使用 JobExecutor 时, AsyncExecutor 不生效。然而咱们建议使用新的 AsyncExecutor 代替JobExecutor ,经过定义两个参数实现

    参数 asyncExecutorEnabled 用于启用异步执行器,代替老的做业执行器。
    参数 asyncExecutorActivate 命令Activiti引擎在启动时启动异步执行器线程池。

ACT_RU_SUSPENDED_JOB:暂停的任务表。如果一个异步任务在运行中,被暂停。就会记录在词表

ACT_RU_TASK:运行中的正常节点任务,
包含:
主键(任务ID),执行实例ID,流程实例ID,流程定义ID,父任务ID,被代理人(OWNER_:通常状况下为空,只有在委托时才有值),经办人(GNEE_:签收人或者委托人),委托状态(DELEGATION_:委托状态 PENDING委托中,RESOLVED已处理),优先级(PRIORITY_),建立时间,截至时间,挂起状态(SUSPENSION_STATE_:暂停状态 1激活 2暂停)

ACT_RU_TIMER_JOB:定时作业表

ACT_RU_VARIABLE:运行中的流程实例变量,流程变量

3.5、ACT_ID_*

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.6、ACT_HI_*

’HI’表示history。就是这些表包含着历史的相关数据,如结束的流程实例,变量,任务,等等。

ACT_HI_ACTINST: 流程实例历史,记录流程流转过的全部节点,包括流程定义ID,流程实例ID,执行节点的ID/名称,执行的指向箭头,办理人ID,开始时间,结束时间,删除缘由等

ACT_HI_ATTACHMENT:实例的历史附件,几乎不会使用,会加大数据库很大的一个loading

ACT_HI_COMMENT:实例的历史备注,存放历史流程的审批意见

ACT_HI_DETAIL:实例流程详细信息

ACT_HI_IDENTITYLINK: 实例节点中,如果指定了目标人,产生的历史。主要存储当前节点参与者的信息,好比参与者ID,参与的流程实例ID,任务ID,参与者扮演的角色类型{assignee(办理者)、candidate(候补者)、owner(委托的办理者)、starter(发起者) 、participant(参与者)}

ACT_HI_PROCINST:流程实例历史

ACT_HI_TASKINST:流程实例的任务历史

ACT_HI_VARINST:流程实例的变量历史

3.7、FLW_*

FLW_CHANNEL_DEFINITION: 泳池管道定义表

FLW_EVENT_DEFINITION:事件定义

FLW_EVENT_DEPLOYMENT:事件必输

FLW_EVENT_RESOURCE:事件所需资源

FLW_EV_DATABASECHANGELOG:Liquibase执行的记录

FLW_EV_DATABASECHANGELOGLOCK:Liquibase执行锁

FLW_RU_BATCH:暂时未知

FLW_RU_BATCH_PART:暂时未知

4、Flowable核心类

4.1、RepositoryService 持久化部署

1.提供了带条件的查询模型流程定义的api
repositoryService.createXXXQuery()
例如:
repositoryService.createModelQuery().list() 模型查询
repositoryService.createProcessDefinitionQuery().list() 流程定义查询repositoryService.createXXXXQuery().XXXKey(XXX) (查询该key是否存在)2.提供一大波模型与流程定义的通用方法
模型相关
repositoryService.getModel()  (获取模型)
repositoryService.saveModel()  (保存模型)
repositoryService.deleteModel() (删除模型)
repositoryService.createDeployment().deploy(); (部署模型)
repositoryService.getModelEditorSource()  (获得模型JSON数据的UTF8字符串)
repositoryService.getModelEditorSourceExtra()  (获取PNG格式图像)3.流程定义相关
repositoryService.getProcessDefinition(ProcessDefinitionId);  获取流程定义具体信息
repositoryService.activateProcessDefinitionById() 激活流程定义
repositoryService.suspendProcessDefinitionById()  挂起流程定义
repositoryService.deleteDeployment()  删除流程定义
repositoryService.getProcessDiagram()获取流程定义图片流
repositoryService.getResourceAsStream()获取流程定义xml流
repositoryService.getBpmnModel(pde.getId()) 获取bpmn对象(当前进行到的那个节点的流程图使用)4.流程定义授权相关
repositoryService.getIdentityLinksForProcessDefinition() 流程定义授权列表
repositoryService.addCandidateStarterGroup()新增组流程授权
repositoryService.addCandidateStarterUser()新增用户流程授权
repositoryService.deleteCandidateStarterGroup() 删除组流程授权
repositoryService.deleteCandidateStarterUser()  删除用户流程授权

4.2、RuntimeService 流程运行

runtimeService.createProcessInstanceBuilder().start() 发起流程
runtimeService.deleteProcessInstance() 删除正在运行的流程
runtimeService.suspendProcessInstanceById() 挂起流程定义
runtimeService.activateProcessInstanceById() 激活流程实例
runtimeService.getVariables(processInstanceId); 获取表单中填写的值
runtimeService.getActiveActivityIds(processInstanceId)获取以进行的流程图节点 (当前进行到的那个节点的流程图使用)runtimeService.createChangeActivityStateBuilder().moveExecutionsToSingleActivityId(executionIds, endId).changeState(); 终止流程

4.3、HistoryService 流程历史服务

注意:包含已完成和为完成的流程实例

historyService.createHistoricProcessInstanceQuery().list() 查询流程实例列表(历史流程,包括未完成的)
historyService.createHistoricProcessInstanceQuery().list().foreach().getValue() 可以获取历史中表单的信息
historyService.createHistoricProcessInstanceQuery().processInstanceId(processInstanceId).singleResult(); 根绝id查询流程实例
historyService.deleteHistoricProcessInstance() 删除历史流程
historyService.deleteHistoricTaskInstance(taskid); 删除任务实例
historyService.createHistoricActivityInstanceQuery().processInstanceId(processInstanceId).list()  流程实例节点列表 (当前进行到的那个节点的流程图使用)

4.4、TaskService 任务服务

流转的节点审批
taskService.createTaskQuery().list() 待办任务列表
taskService.createTaskQuery().taskId(taskId).singleResult();  待办任务详情
taskService.saveTask(task); 修改任务
taskService.setAssignee() 设置审批人
taskService.addComment() 设置审批备注
taskService.complete() 完成当前审批
taskService.getProcessInstanceComments(processInstanceId); 查看任务详情(也就是都经过哪些人的审批,意见是什么)
taskService.delegateTask(taskId, delegater); 委派任务
taskService.claim(taskId, userId);认领任务
taskService.unclaim(taskId); 取消认领
taskService.complete(taskId, completeVariables); 完成任务任务授权
taskService.addGroupIdentityLink()新增组任务授权
taskService.addUserIdentityLink() 新增人员任务授权
taskService.deleteGroupIdentityLink() 删除组任务授权
taskService.deleteUserIdentityLink() 删除人员任务授权

4.5、ManagementService

1、主要是执行自定义命令。

managementService.executeCommand(new classA())  执行classA的内部方法

2、在自定义的方法中可以使用以下方法获取repositoryService。

ProcessEngineConfiguration processEngineConfiguration =CommandContextUtil.getProcessEngineConfiguration(commandContext);
RepositoryService repositoryService = processEngineConfiguration.getRepositoryService();

4.6、IdentityService

操作用户服务的

注意:

 // 设置流程发起者  设置前者可以在历史流程实例中查询到
identityService.setAuthenticatedUserId(sysUser.getUserId());

5、flowable中文文档

flowable中文文档

Flowable基本使用介绍和Flowable数据库表解释相关推荐

  1. destoon数据库表解释说明

    原文地址:destoon数据库表解释说明 作者:安妮的仙境 表名 注释 destoon_404 404日志  destoon_ad 广告  destoon_ad_place 广告位 destoon_a ...

  2. 查看MySQL数据库表的命令介绍

    如果需要查看MySQL数据库中都有哪些MySQL数据库表,应该如何实现呢?下面就为您介绍查看MySQL数据库表的命令,供您参考. 进入MySQL Command line client下 查看当前使用 ...

  3. mysql怎么命令查看表的数据_查看MySQL数据库表的命令介绍

    如果需要查看MySQL数据库中都有哪些MySQL数据库表,应该如何实现呢?下面就为您介绍查看MySQL数据库表的命令,供您参考. 进入MySQL Command line client下 查看当前使用 ...

  4. mysql 表大小_MySQL查看数据库表容量大小的方法示例

    本文介绍MySQL查看数据库表容量大小的命令语句,提供完整查询语句及实例,方便大家学习使用. 1.查看所有数据库容量大小 select table_schema as '数据库', sum(table ...

  5. ER图和关系模型到MySQL数据库表

    本篇主要介绍了MySQL数据库表从ER图到关系模型,再到数据库表的创建过程及其表结构的修改.通过本篇的学习,可以掌握以下内容: ● 应用ER图和关系模型创建数据库表 ● 数据库表结构的修改 1.moo ...

  6. Oracle数据库表中字段顺序的修改方法

    Oracle数据库表中字段顺序的修改方法 这篇文章主要给大家介绍了关于Oracle数据库表中字段顺序的修改方法,在介绍修改的方法之前先给大家介绍了Oracle数据库表新建字段的方法,文中通过示例代码介 ...

  7. oracle 表字段顺序_如何更改Oracle数据库表中字段顺序

    软件安装:装机软件必备包 SQL是Structured Query Language(结构化查询语言)的缩写.SQL是专为数据库而建立的操作命令集,是一种功能齐全的数据库语言.在使用它时,只需要发出& ...

  8. mysql查看数据库表大小语句_MySQL查看数据库表容量大小的命令语句讲解

    MySQL查看数据库表容量大小的命令语句讲解 发布时间:2020-04-27 14:17:23 来源:亿速云 阅读:180 作者:三月 本文主要给大家介绍MySQL查看数据库表容量大小的命令语句讲解, ...

  9. MySQL查看数据库表容量大小

    本文介绍MySQL查看数据库表容量大小的命令语句,提供完整查询语句及实例,方便大家学习使用. 1.查看所有数据库容量大小 select table_schema as '数据库', sum(table ...

最新文章

  1. Info:Memory module [DIMM] needs attention: Single-bit warning error rate exceeded, Single-bit fai...
  2. Jzoj3907 蜀传之单刀赴会(梦回三国系列)
  3. 一轮项目冲刺——移山小分队(2)
  4. OpenGL之利用矩阵的“平移”“旋转”“综合变换”等实现矩形的移动
  5. java核心技术----访问权限
  6. OS- -内存之地址空间
  7. 后缀的形容词_构词法(18)构成形容词的常见后缀 3
  8. Pandas中的元素替换
  9. integer java 随机_如何在Java中生成随机BigInteger值?
  10. SQL Server学习之路(六):“增删改查”之“查”
  11. 0917 词法分析程序(java版)
  12. ngRoute+ngAnimate与JQM中的页面跳转的区别
  13. PMP考试-风险管理专项突破(第六版)
  14. 2.5A双路电机驱动模块 正反转 PWM调速 双H桥 步进电机 超L298N
  15. 计算机一级wpsoffice知识,全国计算机一级WPSOffice考试试题
  16. 史上最简单的 Nginx 教程,没有之一!
  17. Alexa 世界排名推进工具--阿雷克斯(转)
  18. 项目中出现npm WARN locking errno: -4048, npm WARN locking code: ‘EPERM‘, npm WARN locking syscall:
  19. 前端性能优化实践:让视频加载也“懒”一点
  20. leetcode499 迷宫III

热门文章

  1. 210322验证万能近似定理实验记录
  2. Flappy Bird引爆山寨应用热:谁火我就模仿谁
  3. 微信小程序ssm学生作业管理系统
  4. 中国的研究生在“研究”什么
  5. Java实现获取某年某月第一天最后一天
  6. Android的Recovery中font_10x18.h字库文件制作
  7. 如何打开并编辑他人用 Lightly 分享的项目?
  8. [ERP]IPQC是什么意思?IPQC工作职责和IPQC工作流程
  9. 电信4g网速测试软件,移动联通电信三大运营商4G网速测试,仅供非专业人士参考...
  10. 使用xshell连接Ubuntu出现Connecting to 192.168.85.183:22... Could not connect to '192.168.85.183' (port 22)