您的位置:首页 > 产品设计 > 产品经理

JBPM流程部署之部署数据表分析

2011-08-24 21:42 357 查看
JBPM流程部署之部署数据表分析

JBPM流程部署xml格式的流程定义,虽然引擎默认的在发布完后就直接将流程定义实体缓存,以方便以后的流程运行流转使用,避免不必要的数据库访问,但是这些缓存直接存储在内存中,很容易就会丢失掉,比如重启服务器等,所以最终我们还是需要持久化到数据库里。今天我们来了解一下JBPM与流程部署相关的数据库表。

JBPM的持久化层使用的是Java中被广泛使用的ORM框架Hibernate,下面我们看一下JBPM流程部署实体-数据表关系,其关系如下图所示



本来打算使用visio好好的画个图,但是无奈自己能力有限,只能画了个简单的图,下面我们简单的介绍一下

DeploymentImpl 是流程部署的主表,只是简单的记录了一下流程的名称、唯一标示和部署的状态

Lob 是保存xml格式流程定义的,流程部署时的流程xml最终都会序列化成二进制形式保存到这个表里;但是这个表同时也保存运行时的变量数据。

一个部署可以对应多个流程定义数据,即是DeploymentImpl和Lob是一对多的关系

DeploymentProperty 记录流程部署的相关信息,比如流程定义(ProcessDefinitionImpl)的pdid,流程定义的pdkey、流程定义的langid、流程定义的

pdversion;一个流程部署对应一组流程定义相关信息实体,即Deploymentimpl和DeploymentProperty是一对一的关系,但是一个DeploymentImpl

对应四个DeploymentProperty记录

综上所述,我们可以知道JBPM4_DEPLOYMENT的主键是JBPM4_DEPLOYPROP和JBPM4_Lob的外键

下面我们列表分析一下个表字段以及对应的实体字段的意义

JBPM4_DEPLOYMENT 对应实体DeploymentImpl

字段名称数据类型 是否主键是否外键是否可为null实体字段业务意义
DBID_bigintPKnotdbid主键标示
NAME_longtextname[align=center]流程名称[/align]
TIMESTAMP_biginttimestamp部署时间
STATE_ varchar(255)state部署状态
JBPM4_DEPLOYPROP 对应实体为DeploymentProperty

字段名称数据类型 是否主键是否外键 是否可为null实体字段业务意义
DBID_bigintPKnotdbid主键标示
DEPLOYMENT_bigintFKdeployment部署标示
OBJNAME_varchar(255)bjectName部署名称
KEY_varchar(255)key标示本条记录的属性,值为langid、pdid、pdkey、pdversion之一
STRINGVAL_varchar(255)stringValue保存非pdversion对应的值
LONGVAL_bigintlongValue保存Pdversion对应的版本号
JBPM4_LOB 对应实体为Lob

字段名称数据类型 是否主键是否外键 是否可为null实体字段业务意义
DBID_bigintPKnotdbid主键标示
DBVERSION_integernotdbversion[align=center]乐观并发控制[/align]
BLOB_VALUElongblobblob保存流程定义或者变量的二进制形式的资源
DEPLOYMENT_ bigintFKdeployment部署标示
NAME_longtexttext流程定义或者变量的资源的名称
--
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: