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

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
云原生网关 MSE Higress,422元/月
注册配置 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();
}

```

相关文章
|
10天前
|
Java 调度 数据库
SpringBoot整合XXL-JOB【05】- 任务分片
在实际业务中,批量定时任务可能因执行时间过长影响业务。本文介绍如何使用Xxl-job对批量任务进行分片处理,通过分片广播形式调度集群机器并行执行,显著缩短任务耗时。具体步骤包括环境准备、不使用分片的代码示例、使用分片的改造方法及测试结果,展示了分片处理带来的性能提升。
31 13
|
10天前
|
前端开发 Java API
SpringBoot整合Flowable【07】- 驳回节点任务
本文通过绩效流程的业务场景,详细介绍了如何在Flowable工作流引擎中实现任务驳回功能。具体步骤包括:获取目标任务节点和当前任务节点信息,进行必要的判空和逻辑校验,调用API完成节点回退,并清理相关脏数据(如历史任务和变量)。最后通过测试验证了驳回功能的正确性,确保流程能够成功回退到指定节点并清除中间产生的冗余数据。此功能在实际业务中非常有用,能够满足上级驳回自评等需求。
30 0
|
3月前
|
安全 Java 编译器
springboot 整合表达式计算引擎 Aviator 使用示例详解
本文详细介绍了Google Aviator 这款高性能、轻量级的 Java 表达式求值引擎
393 6
消息中间件 缓存 监控
183 0
|
6月前
|
SQL Java 调度
实时计算 Flink版产品使用问题之使用Spring Boot启动Flink处理任务时,使用Spring Boot的@Scheduled注解进行定时任务调度,出现内存占用过高,该怎么办
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
5月前
|
Java 数据安全/隐私保护
SpringBoot 自定义初始化任务 Runner
SpringBoot 自定义初始化任务 Runner
33 0
|
6月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp小程序的校园悬赏任务平台附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp小程序的校园悬赏任务平台附带文章源码部署视频讲解等
66 0
|
6月前
|
Java 数据处理 数据库
Spring Boot中的批处理任务实现
Spring Boot中的批处理任务实现
|
7月前
|
Java 测试技术
springboot延时任务
springboot延时任务
|
7月前
|
Java
springboot自定义log注解支持EL表达式
springboot自定义log注解支持EL表达式
276 0