Springboot整合Activity7:任务,历史任务,UEL表达式(三)

本文涉及的产品
云原生网关 MSE Higress,422元/月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: Springboot整合Activity7:任务,历史任务,UEL表达式(三)

历史任务
介绍
1.当一个实例任务完成后,工作流会自动在任务表等会删除这个记录,并保存在历史表
2.历史表操作就用到 HistoryService

    private HistoryService historyService;

    /**
     * 根据用户名查询历史任务
     */
    @Test
    public void gethistoryTaskInstanceByUser(){
        List<HistoricTaskInstance> list = historyService.createHistoricTaskInstanceQuery()
                .taskAssignee("bajie")
                //排序  asc:正序 desc:倒叙
                .orderByHistoricTaskInstanceEndTime().asc()
                .list();
        for (HistoricTaskInstance hi : list) {
            System.out.println(hi.getId());
            System.out.println(hi.getName());
            System.out.println(hi.getAssignee());
            System.out.println(hi.getProcessInstanceId());

        }
    }

    /**
     * 通过流程实例id查询历史任务
     */
    @Test
    public void gethistoryTaskInstanceByInstance(){
        List<HistoricTaskInstance> list = historyService.createHistoricTaskInstanceQuery()
                .processInstanceId("实例id")
                //排序  asc:正序 desc:倒叙
                .orderByHistoricTaskInstanceEndTime().asc()
                .list();
        for (HistoricTaskInstance hi : list) {
            System.out.println(hi.getId());
            System.out.println(hi.getName());
            System.out.println(hi.getAssignee());
            System.out.println(hi.getProcessInstanceId());

        }
    }

UEL表达式
介绍

  1. 又称统一表达语言,就是在

    1. uel表达式:在启动流程实例,任务完成时可以使用uel表达式携带参数
      基本概述
      运行时的相关数据库
      ————————————————
      ```@Autowired
      private RuntimeService runtimeService;

      @Autowired
      private TaskService taskService;

      /**

      • 启动流程实例时,执行执行人
        */
        @Test
        public void initProcessInstanceWithArgs(){
        //流程变量 //${ZhiXingRen}
        Map variables = new HashMap<>();
        //可以添加多个参数
        variables.put("ZhiXingRen","wukong");

        ProcessInstance processInstance = runtimeService

            .startProcessInstanceByKey("myProcess_UEL_V1","bket01"
            ,variables);
        

        System.out.println("流程实例id:" + processInstance.getProcessDefinitionId());
        }
        /**

      • 完成任务带参数 指定流程变量
        */
        @Test
        public void completeTaskWithArgs(){
        Map variables = new HashMap<>();
        //可以添加多个参数
        variables.put("pay","101");

// taskService.complete("实例id",null);
taskService.complete("60a326bd-8138-11ed-a774-f85ea0a4be6e",variables);
System.out.println("完成任务");
}
/**

 * 启动流程实例携带参数,使用实体类
 */
@Test
public void  initProcessInstanceWithClassArgs(){
    //流程变量实体类
    UEL_POJO uel_pojo = new UEL_POJO();
    uel_pojo.setZhixingren("bajie");

    Map<String,Object> variables = new HashMap<>();
    //可以添加多个参数
    variables.put("uelpojo",uel_pojo);

    ProcessInstance processInstance = runtimeService
            .startProcessInstanceByKey("myProcess_uelv3","bket01"
                    ,variables);
    System.out.println("流程实例id:" + processInstance.getProcessDefinitionId());
}
/**
 * 任务完成带参数,指定多个候选人
 * 01125c1c-813a-11ed-bf93-f85ea0a4be6e
 */
@Test
public void  initProcessInstanceWithCandidataArgs(){
    Map<String,Object> variables = new HashMap<>();
    //可以添加多个参数
    variables.put("houxuanren","wukong,tangseng");

// taskService.complete("实例id",null);
taskService.complete("01125c1c-813a-11ed-bf93-f85ea0a4be6e",variables);
System.out.println("完成任务");
}

/**
 * 直接指定流程变量
 */
@Test
public void  otherArgs(){
    runtimeService.setVariable("实例id","流程变量key","流程变量value");

// runtimeService.setVariables();
}
/**

 * 局部变量
 */
@Test
public void  otherLocalArgs(){
    runtimeService.setVariableLocal("实例id","流程变量key","流程变量value");

// runtimeService.setVariablesLocal();
}

```

相关文章
|
12天前
|
安全 Java 编译器
springboot 整合表达式计算引擎 Aviator 使用示例详解
本文详细介绍了Google Aviator 这款高性能、轻量级的 Java 表达式求值引擎
消息中间件 缓存 监控
106 0
|
3月前
|
Java 数据安全/隐私保护
SpringBoot 自定义初始化任务 Runner
SpringBoot 自定义初始化任务 Runner
16 0
|
4月前
|
SQL Java 调度
实时计算 Flink版产品使用问题之使用Spring Boot启动Flink处理任务时,使用Spring Boot的@Scheduled注解进行定时任务调度,出现内存占用过高,该怎么办
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
4月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp小程序的校园悬赏任务平台附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp小程序的校园悬赏任务平台附带文章源码部署视频讲解等
43 0
|
4月前
|
Java 数据处理 数据库
Spring Boot中的批处理任务实现
Spring Boot中的批处理任务实现
|
5月前
|
Java 测试技术
springboot延时任务
springboot延时任务
|
5月前
|
Java
springboot自定义log注解支持EL表达式
springboot自定义log注解支持EL表达式
192 0
|
5月前
|
SQL API 调度
Springboot2.4.5集成Quartz实现动态任务数据持久化-不怕重启服务
Springboot2.4.5集成Quartz实现动态任务数据持久化-不怕重启服务
181 0
|
5月前
|
Java API 调度
Web后端Javaee企业级开发之定时任务 Springboot整合任务框架Quartz和Task详解
Web后端Javaee企业级开发之定时任务 Springboot整合任务框架Quartz和Task详解
74 0