JBPM表结构

一,概述

      JBPM全称——Java  Business PrcessManagerment(业务流程管理),它是覆盖了业务流程管理、工作流、服务协作等领域的一个开放的、灵活的、易扩展的可执行流程语言框架。

 

二,最大特色

       1)它的业务逻辑定义没有采用目前的一些规范,而是采用了它自己定义的Jboss Jbpm Process Definition Language(jpdl)jpdl任务一个业务流程可以被看作是一个UML状态图。jpdl认为一个业务流程可以被看作是一个UML状态图。jpdl就是详细定义了这个状态图的每个部分,如起始、结束状态,以及状态之间的转换,通过图形化的流程定义,直观地描述业务流程。

      2)使用Hibernate来管理Jbpm的数据库。


三,通过实例介绍Jbpm重要的几张表

(1)Jbpm18张表



(2)涉及到的一些基本流程无非是:

——部署流程定义、启动流程实例、获取个人()任务、高亮显示(查看流程进展图)、完成任务。。。。

 

(3)例:以请假流程为例:

 qingjia.jpdl.xml:

<?xmlversion="1.0" encoding="UTF-8"?>
 
<processname="qingjia1" xmlns="http://jbpm.org/4.4/jpdl"key="qingjia1">
   <start g="246,28,7,3"name="start1">
      <transition g="-71,-17"name="to 申请请假" to="申请请假"/>
   </start>
   <end g="226,320,48,48"name="end1"/>
   <task assignee="张三" g="88,99,92,52" name="申请请假">
      <transition g="-138,5"name="to 部门经理审批" to="部门经理审批"/>
   </task>
   <task assignee="李四" g="233,156,92,52" name="部门经理审批">
      <transition g="3,-26"name="to 总经理审批" to="总经理审批"/>
   </task>
   <task assignee="王二麻子" g="380,226,92,52" name="总经理审批">
      <transition g="-47,-17"name="to end1" to="end1"/>
   </task>
</process>

 

qingjia.png:


 

(1)部署流程定义——从classpath加载jpdl.xml文件

public staticProcessEngine processEngine;
processEngine =Configuration.getProcessEngine();
 
public voidtestDeployFromClasspath(){
processEngine.getRepositoryService()
.createDeployment()
.addResourceFromClasspath("qingjia.jpdl.xml")
.addResourceFromClasspath("qingjia.png")
.deploy();
}


 

涉及到的表:

 

表名(英)

表名(中)                   

说明

字段                              

字段说明

 

Jbpm4_Deployment

部署表

描述一次部署

DBID_

主键、部署ID

 

State

状态 active

 

Jbpm4_Lob

仓库表

存放了流程定义文档(xml、png)

Deployment_

部署ID、外键

 

Name_

Xml或png的文件路径

 

Jbpm4_Deployprop

部署属性表

 

DBID_

主键

 

Objname_

流程定义名称

 

Key_

每部署一次,生成4行记录

 

Langid

语言版本 jpdl-4.4

Pdid

{pdkey-version}

Pdkey

流程定义名称

一般情况下,pdkey和objname_的值是一样的

Pdversion

版本号

如果pdkey没有发生改变,每部署一次,版本号加1;如果pdkey发生改变,则是一个全新的名称,所以版本号应该从1开始计算

 



 

(2)启动流程实例——根据Id启动

public voidtestStartPIByPDID(){
ProcessInstancepi = processEngine.getExecutionService()
.startProcessInstanceById("qingjia1-1");
System.out.println(pi.getId());
System.out.println(pi.getState());
}


 

表名(英)

表名(中)

说明

字段

字段说明

 

Jbpm4_Execution

流程实例表

表示当前正在执行的流程实例

DBID_

主键

 

ID_

流程实例ID

 

ActivityName_

当前流程实例活跃的节点

 

Procdefid_

流程定义ID

 

Jbpm4_Hist_Procinst

历时流程实例表

表示历史的流程实例,但是当前正在运行的流程实例也在这里

DBID_

主键

 

ID_

流程实例ID

 

Start_

整个流程实例的开始时间

 

End_

流程实例的结束时间,如果该流程实例为当前正在运行的流程,则该值为空

 

State

表示流程实例的状态,如果是正在运行为active,如果流程实例结束为ended

 

Jbpm4_task

任务表

表示当前正在执行的任务(任务是jbpm流程图的一个节点)

DBID_

主键、任务ID

临时表,当前任务完成后,数据被删除;

当启动流程实例的时候,会自动离开开始节点,流向下一个节点

Name_

任务名称

 

Assignee_

任务执行人

 

Jbpm4_Hist_Task

历史任务表

表示历史的任务,但是当前正在执行的任务也在这里

State_

如果一个任务被完成以后,值为completed

 

End_

任务结束时间

 

Jbpm4_Hist_Actinst

历时节点表

表示历史的节点

Type

节点类型

 

 

四,表结构总结:

共18张表。红色为常用表

 

(1)资源库与运行时表结构

1. JBPM4_DEPLOYMENT 流程定义表

2. JBPM4_DEPLOYPROP 流程定义属性表

3. JBPM4_EXECUTION  流程实例表

4. JBPM4_PROPERTY  流程引擎表

 

5. JBPM4_TASK 任务表

6. JBPM4_VARIABLE 上下文表

7. JBPM4_JOB  定时表

8. JBPM4_LOB 存储表

9. JBPM4_SWIMLANE泳道表

10. JBPM4_PARTICIPATION 参与者表

 

(2) 历史数据表

11. JBPM4_HIST_ACTINST 流程活动(节点)实例表

12. JBPM4_HIST_DETAIL  流程历史详细表 

13. JBPM4_HIST_PROCINST 流程实例历史表

14. JBPM4_HIST_TASK  流程任务实例历史表

15. JBPM4_HIST_VAR 流程变量(上下文)历史表

 

(3)身份认证表结构

16. JBPM4_ID_GROUP 组表

17. JBPM4_ID_MEMBERSHIP 用户角色表

18. JBPM4_ID_USER  用户表

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 10
    评论
1 ACTIVITI数据库结构 2 1.1 数据库名说明 2 1.2 数据库结构 3 1.2.1 Activiti数据清单: 3 1.2.2 名:ACT_GE_BYTEARRAY (通用的流程定义和流程资源) 3 1.2.3 名:ACT_GE_PROPERTY (系统相关属性) 4 1.2.4 名:ACT_HI_ACTINST (历史节点) 5 1.2.5 名:ACT_HI_ATTACHMENT (附件信息) 6 1.2.6 名:ACT_HI_COMMENT (历史审批意见) 6 1.2.7 名:ACT_HI_DETAIL (历史详细信息) 7 1.2.8 名:ACT_HI_IDENTITYLINK (历史流程人员) 8 1.2.9 名:ACT_HI_PROCINST(历史流程实例信息)核心 8 1.2.10 名:ACT_HI_TASKINST(历史任务流程实例信息)核心 9 1.2.11 名:ACT_HI_VARINST(历史变量信息) 9 1.2.12 名:ACT_ID_GROUP(用户组) 10 1.2.13 名:ACT_ID_INFO (用户扩展信息) 10 1.2.14 名:ACT_ID_MEMBERSHIP(用户用户组关联) 11 1.2.15 名:ACT_ID_USER(用户信息) 11 1.2.16 名:ACT_RE_DEPLOYMENT(部署信息) 12 1.2.17 名:ACT_RE_MODEL (流程设计模型部署) 12 1.2.18 名:ACT_RE_PROCDEF (流程定义) 13 1.2.19 名:ACT_RU_EVENT_SUBSCR (运行时事件) 14 1.2.20 名:ACT_RU_EXECUTION (运行时流程执行实例) 14 1.2.21 名:ACT_RU_IDENTITYLINK(身份联系) 15 1.2.22 名:ACT_RU_JOB(运行中的任务) 15 1.2.23 名:ACT_RU_TASK(运行时任务数据) 16 1.2.24 名:ACT_RU_VARIABLE(运行时流程变量数据) 17 2 ACTIVITI中主要对象的关系 17

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值