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/zh-tw/n/134871.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
UTPU的頭像UTPU
上一篇 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

發表回復

登錄後才能評論