jBPM 4.4 数据库设计

1         存储流程定义相关的部署信息数据库

1.1              jbpm4_deployment


字段名


字段含义


类型


允许空值



DBID_


流程模板标识


Bigint(20)


主键


NAME_


流程模板名称


longtext



TIMESTAMP_


时间戳


Bigint(20)



STATE_


可用状态


Varchar(255)


1.2              jbpm4_deployprop


字段名


字段含义


类型


允许空值



DBID_


属性标识


Bigint(20)


主键


DEPLOYMENT_


流程模板标识


Bigint(20)



外键

jbpm4_deployment>DBID_


OBJNAME_


流程名称


Varchar(255)



KEY_


流程的标识


Varchar(255)



STRINGVAL_


流程的标识对应值


Varchar(255)



LONGVAL_


版本


Bigint(20)


1.3              jbpm4_lob


字段名


字段含义


类型


允许空值



DBID_


标识


Bigint(20)


主键


DBVERSION_


版本


Int(11)


BLOB_VALUE_


流程定义文件(xml/img/class)


longblob



DEPLOYMENT_


流程模板标识


Bigint(20)



外键

jbpm4_deployment>DBID_


NAME_


流程定义文件名


longtext


2         运行类相关数据库

2.1              jbpm4_execution(执行信息表)


字段名


字段含义


类型


允许空值



DBID_


标识


Bigint(20)


主键


CLASS_


Varchar(255)


DBVERSION_


版本


Int(11)


ACTIVITYNAME_


任务实例名


Varchar(255)



PROCDEFID_


流程定义ID


Varchar(255)



HASVARS_


是否有变量值


Bit(1)



NAME_


名称


Varchar(255)



KEY_


Varchar(255)



ID_


令牌ID


Varchar(255)



STATE_


令牌类型


Varchar(255)



SUSPHISTSTATE_


保存暂停之前状态


Varchar(255)



PRIORITY_


优先级


Int(11)



HISACTINST_


历史活动实例ID


Bigint(20)



PARENT_


Bigint(20)



外键

jbpm4_execution> DBID_


INSTANCE_


流程实例


Bigint(20)



外键

jbpm4_execution> DBID_


SUPEREXEC_


父令牌


Bigint(20)



外键

jbpm4_execution> DBID_


SUBPROCINST_


子流程实例


Bigint(20)



外键

jbpm4_execution> DBID_


PARENT_IDX_


Int(11)


2.2              jbpm4_task(存放需要人来完成的活动)


字段名


字段含义


类型


允许空值



DBID_


标识


Bigint(20)


主键


CLASS_


Char(1)


DBVERSION_


版本


Int(11)


NAME_


活动实例名称


Varchar(255)



DESCR_


描述


longtext



STATE_


状态


Varchar(255)



SUSPHISTSTATE_


保存暂停之前状态


Varchar(255)



ASSIGNEE_


处理人


Varchar(255)



FORM_


表单地址


Varchar(255)



PRIORITY_


优先级


Int(11)



CREATE_


创建时间


datetime



DUEDATE_


任务持续时间,表明任务应在多长时间内完成


datetime



PROGRESS_


活动实例名


Int(11)



SIGNALLING_


签收


Bit(1)



EXECUTION_ID_


活动实例ID


Varchar(255)



ACTIVITY_NAME_


活动实例名称


Varchar(255)



HASVARS_


是否有流程变量


Bit(1)



SUPERTASK_


父任务


Bigint(20)



外键

jbpm4_task>DBID_


EXECUTION_


活动实例


Bigint(20)



PROCINST_


流程实例


Bigint(20)



SWIMLANE_


对应的泳道


Bigint(20)



外键

jbpm4_swimlane>DBID_


TASKDEFNAME_


任务定义名


Varchar(255)


2.3              jbpm4_participation(参与者信息)


字段名


字段含义


类型


允许空值



DBID_


标识


Bigint(20)


主键


DBVERSION_


版本


Int(11)


GROUPID_


组ID


Varchar(255)



USERID_


用户ID


Varchar(255)



TYPE_


类型


Varchar(255)



TASK_


任务ID


Bigint(20)



外键

jbpm4_task>DBID_


SWIMLANE_


对应泳道


Bigint(20)



外键

jbpm4_swimlane>DBID_

2.4              jbpm4_swimlane(泳道)


字段名


字段含义


类型


允许空值



DBID_


标识


Bigint(20)


主键


DBVERSION_


版本


Int(11)


NAME_


泳道名


Varchar(255)



ASSIGNEE_


处理人


Varchar(255)



EXECUTION_


活动实例


Varchar(255)



外键

jbpm4_execution>DBID_

2.5              jbpm4_job(存放timer定义)


字段名


字段含义


类型


允许空值



DBID_


标识


Bigint(20)


主键


CLASS_


Varchar(255)


DBVERSION_


版本


Int(11)


DUEDATE_


到期时间


datetime



STATE_


状态


Varchar(255)



ISEXCLUSIVE_


是否可执行


Bit(1)



LOCKOWNER_


锁定的参与者


Varchar(255)



LOCKEXPTIME_


锁定释放时间


datetime



EXCEPTION_


活动实例


longtext



RETRIES_


重复次数


Int(11)



PROCESSINSTANCE_


流程实例


Bigint(20)



EXECUTION_


异常信息


Bigint(20)



CFG_


配置


Bigint(20)



外键

jbpm4_lob>DBID_


SIGNAL_


信号


Varchar(255)



EVENT_


事件


Varchar(255)



REPEAT_


重复


Varchar(255)


2.6              jbpm4_variable(进行时临时变量)


字段名


字段含义


类型


允许空值



DBID_


标识


Bigint(20)


主键


CLASS_


变量类型


Varchar(255)


DBVERSION_


版本


Int(11)


KEY_


变量索引


Varchar(255)



CONVERTER_


数值转换器


Varchar(255)



HIST_


对应的流程实例


Bit(1)



EXECUTION_


活动实例


Bigint(20)



外键

jbpm4_execution>DBID_


TASK_


对应的任务


Bigint(20)



外键

jbpm4_task>DBID_


LOB_


Bigint(20)



外键

jbpm4_lob>DBID_


DATE_VALUE_


当值为date类型时,存值


datetime



DOUBLE_VALUE_


当值为double类型时,存值


double



CLASSNAME_


变量类名


varchar(255)



LONG_VALUE_


当值为long类型时,存值


Bigint(20)



STRING_VALUE_


当值为string类型时,存值


Varchar(255)



TEXT_VALUE_


当值为text类型时,存值


longtext



EXESYS_


Bigint(20)



外键

jbpm4_execution>DBID_

3         历史类相关数据库

3.1              jbpm4_hist_procinst(流程实例)


字段名


字段含义


类型


允许空值



DBID_


标识


Bigint(20)


主键


DBVERSION_


版本


Int(11)


ID_


Varchar(255)



PROCDEFID_


流程定义ID


Varchar(255)



KEY_


Varchar(255)



START_


开始时间


datetime



END_


结束时间


datetime



DURATION_


停留时间


Bigint(20)



STATE_


流程实例状态(活动/完成)


Varchar(255)



ENDACTIVITY_


是否完成


Varchar(255)



NEXTIDX_


Int(11)


3.2              jbpm4_hist_actinst(活动实例)


字段名


字段含义


类型


允许空值



DBID_


标识


Bigint(20)


主键


CLASS_


Activity类型


Varchar(255)


DBVERSION_


版本


Int(11)


HPROCI_


历史流程实例


Bigint(20)



外键

jbpm4_hist_procinst>DBID_


TYPE_


活动实例类型


Varchar(255)



EXECUTION_


令牌


Varchar(255)



ACTIVITY_NAME_


活动实例名称


Varchar(255)



START_


开始时间


datetime



END_


结束时间


datetime



DURATION_


节点停留时间


Bigint(20)



TRANSITION_


迁移路径


Varchar(255)



NEXTIDX_


Int(11)



HTASK_


对应的定义任务


Bigint(20)



外键

jbpm4_hist_task>DBID_

3.3              jbpm4_hist_detail(保存变量的变更记录)


字段名


字段含义


类型


允许空值



DBID_


标识


Bigint(20)


主键


CLASS_


Activity类型


Varchar(255)


DBVERSION_


版本


Int(11)


USERID_


用户ID


Varchar(255)



TIME_


时间


datetime



HPROCI_


对应的历史流程实例


Bigint(20)



外键

jbpm4_hist_procinst>DBID_


HPROCIIDX_


Int(11)



HACTI_


对应的历史活动实例ID


Bigint(20)



外键

jbpm4_hist_actinst>DBID_


HACTIIDX_


Int(11)



HTASK_


对应的任务


Bigint(20)



外键

jbpm4_hist_task>DBID_


HTASKIDX_


Int(11)



HVAR_


对应的变量值


Bigint(20)



外键

jbpm4_hist_var>DBID_


HVARIDX_


int(11)



MESSAGE_


消息


longtext



OLD_STR_


老的String类型值


Varchar(255)



NEW_STR_


新的String类型值


Varchar(255)



OLD_INT_


Int(11)



NEW_INT_


Int(11)



OLD_TIME_


datetime



NEW_TIME_


datetime



PARENT_


变量的父变量


Bigint(20)



PARENT_IDX_


Int(11)


3.4              jbpm4_hist_var(历史变量)


字段名


字段含义


类型


允许空值



DBID_


流程模板标识


Bigint(20)


主键


DBVERSION_


版本


Int(11)


PROCINSTID_


对应运行的流程实例


Varchar(255)



EXECUTIONID_


活动实例ID


Varchar(255)



VARNAME_


变量名称


Varchar(255)



VALUE_



Varchar(255)



HPROCI_


历史流程实例


Bigint(20)



外键

jbpm4_hist_procinst>DBID_


HTASK_


历史任务


Bigint(20)



外键

jbpm4_hist_task>DBID_

3.5              jbpm4_hist_task(任务历史信息)


字段名


字段含义


类型


允许空值



DBID_


标识


Bigint(20)


主键


DBVERSION_


版本


Int(11)


EXECUTION_


令牌


Varchar(255)



OUTCOME_


路径名称


Varchar(255)



ASSIGNEE_


处理人


Varchar(255)



PRIORITY_


优先级


Int(11)



STATE_


完成情况


Varchar(255)



CREATE_


创建时间


datetime



END_


完成时间


datetime



DURATION_


任务节点停留时间


Bigint(20)



NEXTIDX_


Int(11)



SUPERTASK_


父任务


Bigint(20)



外键

jbpm4_hist_task>DBID_

4         权限控制相关数据库

4.1              jbpm4_id_user (用户信息)


字段名


字段含义


类型


允许空值



DBID_


标识


Bigint(20)


主键


DBVERSION_


版本


Int(11)


ID_


用户


Varchar(255)



PASSWORD_


密码


Varchar(255)



GIVENNAME_



Varchar(255)



FAMILYNAME_



Varchar(255)



BUSINESSEMAIL_


电子邮箱


Varchar(255)


4.2              jbpm4_id_group (组信息)


字段名


字段含义


类型


允许空值



DBID_


标识


Bigint(20)


主键


DBVERSION_


版本


Int(11)


ID_



Varchar(255)



NAME_


名称


Varchar(255)



TYPE_


类型


Varchar(255)



PARENT_


父级


Bigint(20)



外键

jbpm4_id_group>DBID_

4.3              jbpm4_id_membership (用户-组信息)


字段名


字段含义


类型


允许空值



DBID_


标识


Bigint(20)


主键


DBVERSION_


版本


Int(11)


USER_


用户标识


Bigint(20)



外键

jbpm4_id_user>DBID_


GROUP_


组标识


Bigint(20)



外键

jbpm4_id_group>DBID_


NAME_


类型


Varchar(255)


时间: 2024-08-30 15:54:38

jBPM 4.4 数据库设计的相关文章

揭秘jbpm流程引擎内核设计思想及构架

作者 胡长城(银狐999) 1     前言 2     阅读本篇的基础准备 2.1      概念的基础 2.2      环境的基础 3     什么是流程引擎内核? 4     引擎内核所关注的四个主要问题 4.1      模型与定义对象 4.2      调度机制与算法 4.3      执行机制与状态 4.4      实例对象与执行环境 5    jbpm,“精简”的开源流程引擎 6    jBpm流程模型与定义对象 6.1      首先解决如何形式化描述一个流程的问题 6.2 

Java精品高级课,架构课,java8新特性,P2P金融项目,程序设计,功能设计,数据库设计,第三方支付,web安全,视频教程

36套精品Java架构师,高并发,高性能,高可用,分布式,集群,电商,缓存,性能调优,设计模式,项目实战,P2P金融项目,大型分布式电商实战视频教程 视频课程包含: 高级Java架构师包含:Spring boot.Spring  cloud.Dubbo.Elasticsearch,Redis.ActiveMQ.Nginx.Mycat.Spring.MongoDB.ZeroMQ.Git.Nosql.Jvm.Mecached.Netty.Nio.Mina.java8新特性,P2P金融项目,程序设计,

数据库设计时不得不违背三范式的情景

1.在进销存系统中,订单信息中关联到好多其他的基本信息,比如:客户,付款方式,货运方式等,这些信息是有专门表进行维护的,在下订单时也是用下拉框选择的,但在保存订单信息时,不能只记录所谓的外键ID,而是应该同时记录名称等其他的信息. 这是因为订单不能因为没有了客户ID或是付款方式ID而不知道客户与付款方式了.对于订单这种客观存在的事物,是具有一定的历史性质的,因此在设计时应该与其他的关联信息可以“断开”,这也就是保证了订单的独立性. 摘自:http://www.cnblogs.com/tongtk

从零开始编写自己的C#框架(9)——数据库设计与创建

对于千万级与百万级数据库设计是有所区别的,由于本项目是基于中小型软件开发框架来设计,记录量相对会比较少,所以数据库设计时考虑的角度是:与开发相结合:空间换性能:空间换开发效率:减少null异常......当然不同的公司与项目要求不同,初学者要学会适应不同的项目开发要求,使用本框架开发时,必须严格按照本章节的要求来设计数据库,不然可能会产生不可控的异常. 从零开始编写自己的C#框架 数据库设计规范   文件状态: [√] 草稿 [  ] 正式发布 [  ] 正在修改 文件标识: C#框架 当前版本

数据库设计的三大范式

数据库设计的三大范式 为了建立冗余较小.结构合理的数据库,设计数据库时必须遵循一定的规则.在关系型数据库中这种规则就称为范式.范式是符合某一种设计要求的总结.要想设计一个结构合理的关系型数据库,必须满足一定的范式. 在实际开发中最为常见的设计范式有三个: 1.第一范式 第一范式是最基本的范式.如果数据库表中的所有字段值都是不可分解的原子值,就说明该数据库表满足了第一范式. 第一范式的合理遵循需要根据系统的实际需求来定.比如某些数据库系统中需要用到"地址"这个属性,本来直接将"

MySql三大范式与数据库设计和表创建常用语句

[数据库设计的三大范式] 1.第一范式(1NF First Normal Fromate):数据表中的每一列(字段),必须是不可拆分的最小单元.也就是确保每一列的原子性. 例如: userInfo: '山东省烟台市 13181621008' => userAds:'山东省烟台市' tel:'13181621008' 2.第二范式(2NF):满足1NF后,要求:表中所有的列,都必须功能依赖于主键,而不能有任何一列与主键没有关系.(一张表值描述一件事情) 3.第三范式(3NF):满足2NF后,要求:

MVC实战之排球计分(一)—— 需求分析与数据库设计

一.需求分析: 这个程序是排球计分程序,其业务非常简单,具体如下: 1.本程序可以选择用户身份,通过不同角度记录比赛分数. 2.不同身份记录的比赛成绩将会存储在不同的数据表(目前适合运动员和观众使用). 3.用户键入数据后,可以继续对数据进行操作(如:删除.修改.查看详情). 4,不同的身份的用户 ,不能修改非己的数据.只能修改自己的数据. 这个项目的用例图如下: 数据库设计:设计数据表之前,首先进行实体和关系的识别与确定.通过需求分析,可以观察得出,本项目的实体有:观众,运动员.(观众可以修改

02-大鸭梨博客系统数据库设计及Dapper的使用

毫无疑问,数据库的设计在一个系统中起了至关重要的作用.我们都知道,系统设计分为两部分,或者说是两个阶段,即数据库设计和功能设计.构建一个完善的系统需要这两个阶段的充分考量.周密设计.合理联接以及密切配合.数据库设计是整个系统的根基,它关乎系统功能的实现.稳定性.扩展性等多个方面,可见数据库设计的重要性. 那么好的数据库设计应该具备什么样的基本条件呢,大致有这么几点: 1.充分体现系统的需求 不管是数据库设计还是功能设计,我们最终的目的都是要实现客户的业务需求,所以数据库设计的第一准则就是要符合业

学生信息管理系统1(数据库设计篇)

1.系统概述 本次是做一个学生管理系统,在学了数据库之后,希望通过这个系统把所学知识应用与实际项目中去.加强自己的熟练程度. 开发背景:具备数据库,C#的相关知识储备,掌握基本的html知识. 用途:仅作练习用.通过一门语言,将数据库展现出来. 2.功能需求分析 系统概念层设计:功能用例图如下 1. 登录功能:用于身份认证 2. 数据操作:信息查询,数据的增删改.a) 数据操作里,管理员具备所有的操作权限.学生具有选课和查看的功能.以及可以修改自己的个人信息.3. UI设计 3.数据库设计 E-