act_ge_property详解

一、概述

act_ge_property 表是 Activiti 引擎的核心数据表之一,主要用于存储引擎的属性配置信息,例如数据库版本号、对于流程和任务的编号生成方式、查询方言、历史数据清理策略等等。

act_ge_property 表是 Activiti 引擎的公共配置表,全局唯一。

二、Schema

表结构

+-----------------+--------------+------+-----+---------+-------+
| Field           | Type         | Null | Key | Default | Extra |
+-----------------+--------------+------+-----+---------+-------+
| NAME_           | varchar(255) | NO   | PRI | NULL    |       |
| REV_            | int(11)      | NO   |     | NULL    |       |
| VALUE_          | varchar(255) | YES  |     | NULL    |       |
| VALUE_BLOB_     | blob         | YES  |     | NULL    |       |
| DEPLOYMENT_ID_  | varchar(64)  | YES  |     | NULL    |       |
+-----------------+--------------+------+-----+---------+-------+

字段说明

NAME_:

该属性的名称。名字必须在 Activiti 引擎中唯一。在代码中,使用该属性必须 specified by a static field ,最好在类开头定义。

REV_ :

版本号,每当更改 VALUE_ 或 VALUE_BLOB_ 时增加。可避免并发更新此值的问题,同时也使在数据迁移期间将属性更改为会产生新版本的属性(具有不同的元版本)变得可能。Rev 值遵循规则:2 REV 值相同的属性必须具有相同的值。

DEPLOYMENT_ID_:

引用的部署,该属性与特定部署相关联。例如,查询方言可能会有不同的部署。为了与实际部署相关的属性,一个实例必须与部署关联。如果特定属性属于特定部署,则此列将包含指向确切部署的指针。如果该属性为全局配置,则该列将显式设为空。

VALUE_:

属性值。如果数据太大,则在VALUE_BLOB_列中存储。

VALUE_BLOB_:

大冗长 / 二进制值的透明存储机制。例如,这是 XML 的嵌入式模型数据。

三、数据字典清单

下面,我们来逐一解析每个数据字典:

1. NAME_

描述

该属性的名称。

取值范围

varchar(255)

是否唯一

是否可以为空:

示例
public static final String DB_SCHEMA_UPDATE = "schema.update";
public static final String DB_SCHEMA_UPDATE_HISTORY = "schema.history";
public static final String PROCESS_DEFINITIONS_CACHE = "process.definitions.cache";
...

2. REV_

描述

版本号。

取值范围

int(11)

是否唯一

是否可以为空

示例
int DATABASE_SCHEMA_UPDATE_VERSION = 7;
int ACTIVITI_VERSION_MAJOR = 7;
int ACTIVITI_VERSION_MINOR = 0;
...

3. VALUE_

描述

属性值。

取值范围

varchar(255)

是否唯一

是否可以为空

示例
updateSchema()
createSchema()
selectOneTaskVariable()
...

4. VALUE_BLOB_

描述

大冗长/二进制值的透明存储机制。

取值范围

blob

是否唯一

是否可以为空

示例

暂无示例。

5. DEPLOYMENT_ID_

描述

引用的部署。

取值范围

varchar(64)

是否唯一

是否可以为空

示例
DeploymentBuilder deploymentBuilder = repositoryService.createDeployment().addClasspathResource("processes/myProcess.bpmn").deploymentProperty("deploymentName", "deploymentOne");

四、常见用法

1. 查询数据库版本信息

查询之前,要先获取到ProcessEngine对象:

ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();

通过ProcessEngine对象获取到RepositoryService对象,并调用getRepositoryService对象中的getProperties方法获取act_ge_property表中的数据库版本信息。

RepositoryService repositoryService = processEngine.getRepositoryService();
List properties = repositoryService.getDeploymentProperties("", DATABASE_TYPE_PROPERTY);

2. 查询任务表中一个任务属性的值

查询之前,要先获取到ProcessEngine对象:

ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();

通过ProcessEngine对象获取到TaskService对象,并调用getVariable方法获取act_ge_property表中的任务属性对应的值。

TaskService taskService = processEngine.getTaskService();
String businessKey = (String) taskService.getVariable(taskId, "businessKey");

3. 更新任务表中一个任务属性的值

更新之前,要先获取到ProcessEngine对象:

ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();

通过ProcessEngine对象获取到TaskService对象,并调用setVariable方法更新act_ge_property表中的任务属性对应的值。

TaskService taskService = processEngine.getTaskService();
taskService.setVariable(taskId, "businessKey", "newBusinessKey");

五、总结

在 Activiti 的架构里,act_ge_property 表是非常重要的一张表。我们可以通过 act_ge_property 表存储引擎的属性配置信息,例如数据库版本号、对于流程和任务的编号生成方式、查询方言、历史数据清理策略等等。

通过本文的介绍,我们了解了 act_ge_property 表的含义、结构和常见用法,这对需要使用 Activiti 引擎进行开发的开发者来说是非常有帮助的。

原创文章,作者:UTPU,如若转载,请注明出处:https://www.506064.com/n/134871.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
UTPUUTPU
上一篇 2024-10-04 00:08
下一篇 2024-10-04 00:08

相关推荐

  • 神经网络代码详解

    神经网络作为一种人工智能技术,被广泛应用于语音识别、图像识别、自然语言处理等领域。而神经网络的模型编写,离不开代码。本文将从多个方面详细阐述神经网络模型编写的代码技术。 一、神经网…

    编程 2025-04-25
  • Linux sync详解

    一、sync概述 sync是Linux中一个非常重要的命令,它可以将文件系统缓存中的内容,强制写入磁盘中。在执行sync之前,所有的文件系统更新将不会立即写入磁盘,而是先缓存在内存…

    编程 2025-04-25
  • Linux修改文件名命令详解

    在Linux系统中,修改文件名是一个很常见的操作。Linux提供了多种方式来修改文件名,这篇文章将介绍Linux修改文件名的详细操作。 一、mv命令 mv命令是Linux下的常用命…

    编程 2025-04-25
  • Python安装OS库详解

    一、OS简介 OS库是Python标准库的一部分,它提供了跨平台的操作系统功能,使得Python可以进行文件操作、进程管理、环境变量读取等系统级操作。 OS库中包含了大量的文件和目…

    编程 2025-04-25
  • MPU6050工作原理详解

    一、什么是MPU6050 MPU6050是一种六轴惯性传感器,能够同时测量加速度和角速度。它由三个传感器组成:一个三轴加速度计和一个三轴陀螺仪。这个组合提供了非常精细的姿态解算,其…

    编程 2025-04-25
  • git config user.name的详解

    一、为什么要使用git config user.name? git是一个非常流行的分布式版本控制系统,很多程序员都会用到它。在使用git commit提交代码时,需要记录commi…

    编程 2025-04-25
  • Java BigDecimal 精度详解

    一、基础概念 Java BigDecimal 是一个用于高精度计算的类。普通的 double 或 float 类型只能精确表示有限的数字,而对于需要高精度计算的场景,BigDeci…

    编程 2025-04-25
  • C语言贪吃蛇详解

    一、数据结构和算法 C语言贪吃蛇主要运用了以下数据结构和算法: 1. 链表 typedef struct body { int x; int y; struct body *nex…

    编程 2025-04-25
  • nginx与apache应用开发详解

    一、概述 nginx和apache都是常见的web服务器。nginx是一个高性能的反向代理web服务器,将负载均衡和缓存集成在了一起,可以动静分离。apache是一个可扩展的web…

    编程 2025-04-25
  • Python输入输出详解

    一、文件读写 Python中文件的读写操作是必不可少的基本技能之一。读写文件分别使用open()函数中的’r’和’w’参数,读取文件…

    编程 2025-04-25

发表回复

登录后才能评论