成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Flowable 設置流程變量的四種方式

開發 前端
我們可以在啟動的時候為流程設置變量,小伙伴們注意到,流程變量的 value 也可以是一個對象(不過這個對象要能夠序列化,即實現了 Serializable 接口),然后在啟動的時候傳入這個變量即可。

在之前的文章中,松哥也有和小伙伴們使用過流程變量,然而沒有和大家系統的梳理過流程變量的具體玩法以及它對應的數據表詳情,今天我們就來看看 Flowable 中流程變量的詳細玩法。

1. 為什么需要流程變量

首先我們來看看為什么需要流程變量。

舉一個簡單的例子,假設我們有如下一個流程:

圖片

這是一個請假流程,那么誰請假、請幾天、起始時間、請假理由等等,這些都需要說明,不然領導審批的依據是啥?那么如何傳遞這些數據,我們就需要流程變量。

2. 流程變量的分類

整體上來說,目前流程變量可以分為三種類型:

全局流程變量:在整個流程執行期間,這個流程變量都是有效的。

本地流程變量:這個只針對流程中某一個具體的 Task(任務)有效,這個任務執行完畢后,這個流程變量就失效了。

臨時流程變量:顧名思義就是臨時的,這個不會存入到數據庫中。

在接下來的內容中,我會跟大家挨個介紹這些流程變量的用法。

3. 全局流程變量

假設我們就是上面這個請假流程,我們一起來看下流程變量的設置和獲取。

3.1 啟動時設置

第一種方式,就是我們可以在流程啟動的時候,設置流程變量,如下:

@Test
void test01(){
Map<String, Object> variables = new HashMap<>();
variables.put("days", 10);
variables.put("reason", "休息一下");
variables.put("startTime", new Date());
ProcessInstance pi = runtimeService.startProcessInstanceByKey("demo01", variables);
logger.info("id:{},activityId:{}", pi.getId(), pi.getActivityId());
}

我們可以在啟動的時候為流程設置變量,小伙伴們注意到,流程變量的 value 也可以是一個對象(不過這個對象要能夠序列化,即實現了 Serializable 接口),然后在啟動的時候傳入這個變量即可。

我們在流程啟動日志中搜索 休息一下 四個字,可以找到和流程變量相關的 SQL,一共有兩條,如下:

insert into ACT_HI_VARINST (ID_, PROC_INST_ID_, EXECUTION_ID_, TASK_ID_, NAME_, REV_, VAR_TYPE_, SCOPE_ID_, SUB_SCOPE_ID_, SCOPE_TYPE_, BYTEARRAY_ID_, DOUBLE_, LONG_ , TEXT_, TEXT2_, CREATE_TIME_, LAST_UPDATED_TIME_) values ( ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ? ) , ( ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ? ) , ( ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ? )

INSERT INTO ACT_RU_VARIABLE (ID_, REV_, TYPE_, NAME_, PROC_INST_ID_, EXECUTION_ID_, TASK_ID_, SCOPE_ID_, SUB_SCOPE_ID_, SCOPE_TYPE_, BYTEARRAY_ID_, DOUBLE_, LONG_ , TEXT_, TEXT2_) VALUES ( ?, 1, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ? ) , ( ?, 1, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ? ) , ( ?, 1, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ? )

從標名稱上大概就能看出來,ACT_HI_VARINST 是存儲流程執行的歷史信息的,ACT_RU_VARIABLE 則是保存流程運行時候的信息的。

我們打開 ACT_RU_VARIABLE 表來看一下:

圖片

從表中我們可以看到,每一個流程變量都有對應的流程實例 ID,這就說明這些流程變量是屬于某一個流程實例的,所以我們可以按照如下方式來查詢流程變量:

@Test
void test01(){
List<Execution> list = runtimeService.createExecutionQuery().list();
for (Execution execution : list) {
Object reason = runtimeService.getVariable(execution.getId(), "reason");
logger.info("reason:{}", reason);
}
}

對應的查詢 SQL 如下:

: ==>  Preparing: select * from ACT_RU_VARIABLE WHERE EXECUTION_ID_ = ? AND TASK_ID_ is null AND NAME_ = ?
: ==> Parameters: 6fdd2007-4c3a-11ed-aa7e-acde48001122(String), reason(String)
: <== Total: 1

可以看到,這個就是去 ACT_RU_VARIABLE 表中進行查詢,查詢條件中包含了變量的名稱。

當然,我們也可以直接查詢某一個流程的所有變量,如下:

@Test
void test02(){
List<Execution> list = runtimeService.createExecutionQuery().list();
for (Execution execution : list) {
Map<String,Object> variables = runtimeService.getVariables(execution.getId());
logger.info("variables:{}", variables);
}
}

這個對應的查詢 SQL 如下:

: ==>  Preparing: select * from ACT_RU_VARIABLE WHERE EXECUTION_ID_ = ? AND TASK_ID_ is null
: ==> Parameters: 6fdd2007-4c3a-11ed-aa7e-acde48001122(String)
: <== Total: 3

可以看到,這個跟上面的那個差不多,只不過少了 NAME_ 這個條件。

3.2 通過 Task 設置

我們也可以在流程啟動成功之后,再去設置流程變量,步驟如下:

首先啟動一個流程:

@Test
void test01(){
ProcessInstance pi = runtimeService.startProcessInstanceByKey("demo01");
logger.info("id:{},activityId:{}", pi.getId(), pi.getActivityId());
}

然后設置流程變量:

@Test
void test03(){
Task task = taskService.createTaskQuery().singleResult();
taskService.setVariable(task.getId(), "days", 10);
Map<String, Object> variables = new HashMap<>();
variables.put("reason", "休息一下");
variables.put("startTime", new Date());
taskService.setVariables(task.getId(),variables);
}

查詢到某一個 Task,然后設置流程變量,上面這段代碼和小伙伴們演示了兩種設置方式:

  • 逐個設置
  • 直接設置一個 Map

上面這個設置流程變量的方式,本質上還是往 ACT_HI_VARINST 和 ACT_RU_VARIABLE 表中插入數據。具體的 SQL 也和前面的一樣,我就不貼出來了。

3.3 完成任務時設置

也可以在完成一個任務的時候設置流程變量,如下:

@Test
void test04(){
Task task = taskService.createTaskQuery().singleResult();
Map<String, Object> variables = new HashMap<>();
variables.put("reason", "休息一下");
variables.put("startTime", new Date());
variables.put("days", 10);
taskService.complete(task.getId(),variables);
}

底層涉及到的 SQL 都跟前面一樣,我就不贅述了。

3.4 通過流程設置

由于是全局流程變量,所以我們也可以通過 RuntimeService 來進行設置,如下:

@Test
void test05(){
Execution execution = runtimeService.createExecutionQuery().singleResult();
runtimeService.setVariable(execution.getId(), "days", 10);
Map<String, Object> variables = new HashMap<>();
variables.put("reason", "休息一下");
variables.put("startTime", new Date());
runtimeService.setVariables(execution.getId(), variables);
}

好啦,一共就是這四種方式。

4. 本地流程變量

第三小節我們說的全局流程變量是和某一個具體的流程綁定的,而本地流程變量則不同,本地流程變量和某一個 Task 綁定。

4.1 通過 Task 設置

假設我們啟動流程之后,通過 Task 來設置一個本地流程變量,方式如下:

@Test
void test03(){
Task task = taskService.createTaskQuery().singleResult();
taskService.setVariableLocal(task.getId(), "days", 10);
Map<String, Object> variables = new HashMap<>();
variables.put("reason", "休息一下");
variables.put("startTime", new Date());
taskService.setVariables(task.getId(),variables);
}

上面這段代碼中,我設置了一個本地變量,兩個全局變量,設置完成后,我們去 ACT_RU_VARIABLE 表中來查看一下具體的效果。

圖片

大家看到,由于 days 是本地變量,所以它的 TASK_ID_ 有值,這個好理解,說明 days 這個變量和這個具體的 Task 是有關的。

此時如果我們完成這個 Task,代碼如下:

@Test
void test06(){
Task task = taskService.createTaskQuery().singleResult();
taskService.complete(task.getId());
}

完成之后,再來查看 ACT_RU_VARIABLE 表,如下:

我們發現本地變量 days 已經沒有了。因為上一個 Task 都已經執行完畢了,這個時候如果還是按照第三小節介紹的方式去查詢變量,就查不到 days 了。此時如果需要查詢到曾經的 days 變量,得去歷史表中查詢了,方式如下:

@Test
void test07(){
ProcessInstance pi = runtimeService.createProcessInstanceQuery().singleResult();
List<HistoricVariableInstance> list = historyService.createHistoricVariableInstanceQuery().processInstanceId(pi.getId()).list();
for (HistoricVariableInstance hvi : list) {
logger.info("name:{},type:{},value:{}", hvi.getVariableName(), hvi.getVariableTypeName(), hvi.getValue());
}
}

這是流程本地變量的特點,當然相關的方法還有好幾個,這里列出來給小伙伴們參考:

  • org.flowable.engine.TaskService#complete(java.lang.String, java.util.Map<java.lang.String,java.lang.Object>, boolean):在完成一個 Task 的時候,如果傳遞了變量,則可以通過第三個參數來控制這個變量是全局的還是本地的,true 表示這個變量是本地的。
  • org.flowable.engine.RuntimeService#setVariableLocal:為某一個執行實例設置本地變量。
  • org.flowable.engine.RuntimeService#setVariablesLocal:同上,批量設置。

好啦,這就是本地流程變量。

5. 臨時流程變量

臨時流程變量是不存數據庫的,一般來說我們可以在啟動流程或者完成任務的時候使用,用法如下:

@Test
void test21(){
Map<String, Object> variables = new HashMap<>();
variables.put("reason", "休息一下");
variables.put("startTime", new Date());
ProcessInstance pi = runtimeService
.createProcessInstanceBuilder()
.transientVariable("days", 10)
.transientVariables(variables)
.processDefinitionKey("demo01")
.start();
logger.info("id:{},activityId:{}", pi.getId(), pi.getActivityId());
}

上面這段代碼涉及到的流程變量就是臨時流程變量,它是不會存入到數據庫中的。

也可以在完成一個任務的時候設置臨時變量,如下:

@Test
void test22(){
Task task = taskService.createTaskQuery().singleResult();
Map<String, Object> transientVariables = new HashMap<>();
transientVariables.put("days", 10);
taskService.complete(task.getId(), null, transientVariables);
}

這個臨時變量也是不會存入到數據庫中的。

責任編輯:武曉燕 來源: 江南一點雨
相關推薦

2022-10-09 18:16:01

Flowable設置ReceiveTas

2023-03-27 14:46:46

人工智能物聯網

2023-05-22 08:03:28

JavaScrip枚舉定義

2022-03-25 14:47:24

Javascript數據類型開發

2010-07-28 13:54:42

Flex數據綁定

2017-04-17 19:31:03

Android多線程

2021-12-22 09:34:01

Golagn配置方式

2014-12-25 09:41:15

Android加載方式

2023-09-14 13:22:00

數字技術AR

2020-06-12 08:28:29

JavaScript開發技術

2013-06-14 15:24:57

Android開發移動開發數據存儲方式

2013-10-17 09:25:52

2021-07-14 10:31:15

JavaScript開發 技巧

2021-12-01 15:40:40

節日開源剪貼畫

2015-04-02 16:54:52

災難恢復VDI災難恢復

2015-04-13 11:39:26

VDI災難恢復

2025-05-09 09:39:45

2024-01-17 13:56:00

Redis節點映射關系

2022-07-04 08:29:13

electron通信

2021-06-25 08:00:00

物聯網醫療技術
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美亚洲国产成人 | 国产视频1区 | 国产美女自拍视频 | 国产欧美一区二区在线观看 | 91国产精品 | 成人影院在线视频 | 国产人成在线观看 | 亚洲免费在线 | 久久99精品国产 | 亚洲精品九九 | 国产精品一区二区久久精品爱微奶 | 午夜寂寞影院列表 | 99热这里都是精品 | 久久久91| 欧美视频第三页 | 一区二区三区四区av | 99国产精品99久久久久久 | 人人叉| www.日本在线 | 色久影院 | 91人人爽 | 欧美在线视频一区二区 | a久久久久久 | 在线观看特色大片免费网站 | 777777777亚洲妇女 | 国产中文字幕在线观看 | 成人精品一区二区三区中文字幕 | 国产午夜亚洲精品不卡 | 久久i| 久久综合色综合 | 国产一区二区三区在线 | av av在线| 一级黄色生活视频 | 特黄毛片| 欧美一区视频在线 | 激情五月婷婷 | 亚洲 欧美 精品 | 二区精品| 国产一区二 | 一区二区三区国产在线观看 | 久久大全 |