万字解析Activiti7流程框架(二)

简介: 万字解析Activiti7流程框架

3.ProcessDefinition-流程定义操作:


流程定义操作主要针对的就是我们提前画好的BPMN文件的详细信息


这里我们先来看看我们的BPMN文件是什么样的


20201215141030570.png


可以看到我们的流程定义的信息是这样的,那么接下来我们在看看我们的流程定义的读取操作读出来的信息是不是和我们定义的一样呢?


3.1-ProcessDefinition文件读取:


20201215141046668.png


可以看到读取到的信息也的确是一样的,并且因为我们的流程Key没有发生改变,所以我们的版本是不一样的,并且采用+1操作的方式


3.2-ProcessDefinition文件删除:

//删除流程定义
    @Test
    public void delDefinition(){
        String pdID="fadb560c-3b76-11eb-a72f-3c58c24c1a1b";
        repositoryService.deleteDeployment(pdID,true);
        System.out.println(  );
    }

这里我们想要删除我们定义的流程,就需要获得我们的Deployment的ID号,就是我们在上面查询Deployment获得的ID号.并且他会有一个选项即boolen的选项


true代表删除该流程的一切历史信息包括该流程的相关信息以及部署该流程的过程的详细信息,以及该流程文件的详细信息,反正就是所有的信息


false代表只删除该流程的信息,其他的信息是不会删除的.即只删除act_re_procdef表中的记录.


这里我们测试完成之后,可以发现已经测试成功了


20201215141109156.png


那么接下来我们再去看看数据库里的信息发生率什么样的变化.


首先是act_re_procdef表,可以看到只剩下了一条数据了


2020121514112317.png


我们再来看看act_re_deploymemt关于该流程的记录因为已经是删除了


20201215141137285.png


最后我们再来看看act_ge_bytearray,发现该流程部署的两条文件数据也已近删除了,只剩下两条数据了.


20201215141149991.png


这下我们便能更好的理解true和false的区别了


4.ProcessInstance-流程实例操作:


在学习下面的操作之前我们首先需要明白ProcessDefinition和Processinstance的区别.


ProcessDefinition指的是我们定义的流程,这个流程只是一个一般化的流程,就比方说请假,我们只是定义了请假的一般化流程,比如说各个层级请假需要经过哪些层级的审核等等


但是Processinstance指的则是我们已经创建好的一个流程实例,比方说今天小赵想要请假,那么就会根据上面的定义流程创建一个流程是只适用于小赵的请假流程,然后今天小余也像请假,呢么就肯定要在根据上面定义的实例再创建一个实例是只适用于小余的,那么我们就能了解这两者的区别以及联系了


简单来说就可以用下面的图来表示:


一对多的关系.流程只是一个一般化的过程,流程实例是需要与特定的业务数据进行绑定的


20201215141204546.png


了解完两者的区别之后,我们就能继续下面的操作了.


4.1-ProcessInstance-流程实例定义操作:


    @Autowired
    private RuntimeService runtimeService;
    //初始化流程实例
    @Test
    public void initProcessInstance(){
        //获取页面表单填报的内容,比如说请假时间,请假事由等等数据
        //将填好的数据写入我们的业务表里,返回业务表的主键ID=====>BussinessKey
        //之后就需要将我们的业务数据绑定到流程上,这样创建出来的流程实例既能表现流程,同时又能够体现出我们系统的业务数据
        ProcessInstance processInstance=runtimeService.startProcessInstanceByKey("myProcess_Part1","bKey0001");
        System.out.println("ID:"+processInstance.getId());
        System.out.println("ProcessInstanceId:"+processInstance.getProcessInstanceId());
        System.out.println("ProcessDefinitionId:"+processInstance.getProcessDefinitionId());
    }


这里我们定义流程实例是通过Key以及businessKey来进行定义的


20201215141218476.png


这里我们需要重点理解的businessKey,其实这个key就是我们上面讲到的业务数据,一般我们定义流程实例之前都需要将我们本次流程实例需要绑定的业务数据的信息定义出来,定义出来时候,该业务数据本身就会有他自己的ID,那么我们创建流程实例的时候就只需要将该流程实例与该业务数据的ID绑定之后,那么完整的流程实例就已经创建好了,确切的创建流程实例的过程应该是这样的


20201215141233534.png


理解上面的概念之后,我们来执行以下代码,可以发现已经执行成功了.


20201215141247539.png


那么我们再来看看数据库中的信息会发生怎么样的变化.


首先我们先看到的就是act_ru_execution表里面增加了两条信息,为什么增加的是两条信息,大家可能要问了,这主要是因为我们的BPMN文件里面都是定义了一个起始结点以及一个结束结点的,所以会增加两条记录.


接着我们再看,就是能够发现我们的数据已经和我们定义的业务数据绑定了,这样后续我们查找该流程实例的业务数据后悔方便很多,直接关联我们的业务数据表进行关联查询即可.


20201215141259486.png


还有一个表的数据是发生了变化的,就是act_ru_identitylink,这张表主要就是记录我们流程过程中参与流程的人员身份,这其中的人员身份只包括我们在BPMN文件里面定义的用户信息,并且这个信息应该只是代表一种身份,并不具体到确切的个人,只是我们这里定义的时候为了方便大家理解,选择使用bajie来替换,确切的人员信息应该是在业务数据里面定义的


2020121514131176.png


这样我们的流式实例定义操作就已经结束了.


4.2-ProcessInstance-流程实例查询操作:

 //获取流程实例列表
    @Test
    public void getProcessInstances(){
        List<ProcessInstance>processInstances=runtimeService.createNativeProcessInstanceQuery().list();
        for(ProcessInstance processInstance:processInstances){
            //流程实例ID
            System.out.println("ProcessInstanceId:"+processInstance.getProcessInstanceId());
            //流程定义ID
            System.out.println("ProcessDefinitionId:"+processInstance.getProcessDefinitionId());
            //流程实例是否已经执行结束
            System.out.println("isEnded:"+processInstance.isEnded());
            //流程实例是否已经挂起
            System.out.println("isSuspended:"+processInstance.isSuspended());
        }
    }

执行完代码之后我们就能够发现是的确已经执行成功了


2020121514132537.png


4.3-ProcessInstance-流程实例挂起激活操作:

    //暂停与激活流程实例
    @Test
    public void activitieProcessInstances(){
        runtimeService.suspendProcessInstanceById("bcad5409-3db6-11eb-87c1-3c58c24c1a1b");
        System.out.println("流程实例挂起成功");
//        runtimeService.activateProcessInstanceById("bcad5409-3db6-11eb-87c1-3c58c24c1a1b");
//        System.out.println("流程实例激活成功");
    }


我们首先先测试流程实例的挂起操作


20201215141338520.png


嘴上说挂起成功没用,这时候我们重新去查询一下所有的流程实例,并且看看他们的状态


20201215141350953.png


可以看到该流程实例奇缺已经挂起了


这时候我们重新将该流程实例重新激活


20201215141405508.png


我们在重新去查看一下所有的流程实例


20201215141421877.png


可以看到该流程实例的确已经激活了


4.4-ProcessInstance-流程实例删除操作:


    //删除流程实例
    @Test
    public void delProcessInstances(){
        runtimeService.deleteProcessInstance("bcad5409-3db6-11eb-87c1-3c58c24c1a1b","拜拜了您嘞");
        System.out.println("流程实例删除成功");
    }


这里我们选择删除我们上面定义的流程实例,我们主要看第二个属性


20201215141438389.png


可以看到Activiti7要求删除流程实例的时候必须要提供一个删除的原因,这个主要就是为了迎合我们的业务数据,我们停掉某个流程,很明显都是有原因的,那么我们就肯定是要记录这个原因的,所以Activiti7要求我们记录该原因.


接着我们测试一下删除流程实例的代码


20201215141452863.png


可以看到该流程实例已经被成功删除掉了,我们这时候再去查看流程实例


20201215141505225.png


可以看到已经没有流程实例,说明我们已经成功将该流程实例删除掉了.


相关文章
|
1月前
|
存储 域名解析 弹性计算
阿里云上云流程参考:云服务器+域名+备案+域名解析绑定,全流程图文详解
对于初次通过阿里云完成上云的企业和个人用户来说,很多用户不仅是需要选购云服务器,同时还需要注册域名以及完成备案和域名的解析相关流程,从而实现网站的上线。本文将以上云操作流程为核心,结合阿里云的活动政策与用户系统梳理云服务器选购、域名注册、备案申请及域名绑定四大关键环节,以供用户完成线上业务部署做出参考。
|
10月前
|
监控 安全 开发工具
鸿蒙HarmonyOS应用开发 | HarmonyOS Next-从应用开发到上架全流程解析
HarmonyOS Next是华为推出的最新版本鸿蒙操作系统,强调多设备协同和分布式技术,提供丰富的开发工具和API接口。本文详细解析了从应用开发到上架的全流程,包括环境搭建、应用设计与开发、多设备适配、测试调试、应用上架及推广等环节,并介绍了鸿蒙原生应用开发者激励计划,帮助开发者更好地融入鸿蒙生态。通过DevEco Studio集成开发环境和华为提供的多种支持工具,开发者可以轻松创建并发布高质量的鸿蒙应用,享受技术和市场推广的双重支持。
1583 11
|
7月前
|
人工智能 API 开发者
HarmonyOS Next~鸿蒙应用框架开发实战:Ability Kit与Accessibility Kit深度解析
本书深入解析HarmonyOS应用框架开发,聚焦Ability Kit与Accessibility Kit两大核心组件。Ability Kit通过FA/PA双引擎架构实现跨设备协同,支持分布式能力开发;Accessibility Kit提供无障碍服务构建方案,优化用户体验。内容涵盖设计理念、实践案例、调试优化及未来演进方向,助力开发者打造高效、包容的分布式应用,体现HarmonyOS生态价值。
393 27
|
7月前
|
人工智能 自然语言处理 搜索推荐
ViDoRAG:开源多模态文档检索框架,多智能体推理+图文理解精准解析文档
ViDoRAG 是阿里巴巴通义实验室联合中国科学技术大学和上海交通大学推出的视觉文档检索增强生成框架,基于多智能体协作和动态迭代推理,显著提升复杂视觉文档的检索和生成效率。
398 8
ViDoRAG:开源多模态文档检索框架,多智能体推理+图文理解精准解析文档
|
8月前
|
编解码 缓存 Prometheus
「ximagine」业余爱好者的非专业显示器测试流程规范,同时也是本账号输出内容的数据来源!如何测试显示器?荒岛整理总结出多种测试方法和注意事项,以及粗浅的原理解析!
本期内容为「ximagine」频道《显示器测试流程》的规范及标准,我们主要使用Calman、DisplayCAL、i1Profiler等软件及CA410、Spyder X、i1Pro 2等设备,是我们目前制作内容数据的重要来源,我们深知所做的仍是比较表面的活儿,和工程师、科研人员相比有着不小的差距,测试并不复杂,但是相当繁琐,收集整理测试无不花费大量时间精力,内容不完善或者有错误的地方,希望大佬指出我们好改进!
551 16
「ximagine」业余爱好者的非专业显示器测试流程规范,同时也是本账号输出内容的数据来源!如何测试显示器?荒岛整理总结出多种测试方法和注意事项,以及粗浅的原理解析!
|
7月前
|
监控 Shell Linux
Android调试终极指南:ADB安装+多设备连接+ANR日志抓取全流程解析,覆盖环境变量配置/多设备调试/ANR日志分析全流程,附Win/Mac/Linux三平台解决方案
ADB(Android Debug Bridge)是安卓开发中的重要工具,用于连接电脑与安卓设备,实现文件传输、应用管理、日志抓取等功能。本文介绍了 ADB 的基本概念、安装配置及常用命令。包括:1) 基本命令如 `adb version` 和 `adb devices`;2) 权限操作如 `adb root` 和 `adb shell`;3) APK 操作如安装、卸载应用;4) 文件传输如 `adb push` 和 `adb pull`;5) 日志记录如 `adb logcat`;6) 系统信息获取如屏幕截图和录屏。通过这些功能,用户可高效调试和管理安卓设备。
|
7月前
|
机器学习/深度学习 人工智能 Java
Java机器学习实战:基于DJL框架的手写数字识别全解析
在人工智能蓬勃发展的今天,Python凭借丰富的生态库(如TensorFlow、PyTorch)成为AI开发的首选语言。但Java作为企业级应用的基石,其在生产环境部署、性能优化和工程化方面的优势不容忽视。DJL(Deep Java Library)的出现完美填补了Java在深度学习领域的空白,它提供了一套统一的API,允许开发者无缝对接主流深度学习框架,将AI模型高效部署到Java生态中。本文将通过手写数字识别的完整流程,深入解析DJL框架的核心机制与应用实践。
411 3
|
8月前
|
Java 数据库 开发者
详细介绍SpringBoot启动流程及配置类解析原理
通过对 Spring Boot 启动流程及配置类解析原理的深入分析,我们可以看到 Spring Boot 在启动时的灵活性和可扩展性。理解这些机制不仅有助于开发者更好地使用 Spring Boot 进行应用开发,还能够在面对问题时,迅速定位和解决问题。希望本文能为您在 Spring Boot 开发过程中提供有效的指导和帮助。
973 12

推荐镜像

更多
  • DNS