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

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介: 万字解析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


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


相关文章
|
28天前
|
存储 Java
深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。
【10月更文挑战第16天】本文深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。HashSet基于哈希表实现,添加元素时根据哈希值分布,遍历时顺序不可预测;而TreeSet利用红黑树结构,按自然顺序或自定义顺序存储元素,确保遍历时有序输出。文章还提供了示例代码,帮助读者更好地理解这两种集合类型的使用场景和内部机制。
38 3
|
1月前
|
XML JSON API
ServiceStack:不仅仅是一个高性能Web API和微服务框架,更是一站式解决方案——深入解析其多协议支持及简便开发流程,带您体验前所未有的.NET开发效率革命
【10月更文挑战第9天】ServiceStack 是一个高性能的 Web API 和微服务框架,支持 JSON、XML、CSV 等多种数据格式。它简化了 .NET 应用的开发流程,提供了直观的 RESTful 服务构建方式。ServiceStack 支持高并发请求和复杂业务逻辑,安装简单,通过 NuGet 包管理器即可快速集成。示例代码展示了如何创建一个返回当前日期的简单服务,包括定义请求和响应 DTO、实现服务逻辑、配置路由和宿主。ServiceStack 还支持 WebSocket、SignalR 等实时通信协议,具备自动验证、自动过滤器等丰富功能,适合快速搭建高性能、可扩展的服务端应用。
101 3
|
1月前
|
JavaScript 前端开发 开发者
Vue执行流程及渲染解析
【10月更文挑战第2天】
104 58
|
12天前
|
存储 Java 开发者
Java中的集合框架深入解析
【10月更文挑战第32天】本文旨在为读者揭开Java集合框架的神秘面纱,通过深入浅出的方式介绍其内部结构与运作机制。我们将从集合框架的设计哲学出发,探讨其如何影响我们的编程实践,并配以代码示例,展示如何在真实场景中应用这些知识。无论你是Java新手还是资深开发者,这篇文章都将为你提供新的视角和实用技巧。
12 0
|
1月前
|
Web App开发 IDE 测试技术
自动化测试的利器:Selenium 框架深度解析
【10月更文挑战第2天】在软件开发的海洋中,自动化测试犹如一艘救生艇,让质量保证的过程更加高效与精准。本文将深入探索Selenium这一强大的自动化测试框架,从其架构到实际应用,带领读者领略自动化测试的魅力和力量。通过直观的示例和清晰的步骤,我们将一起学习如何利用Selenium来提升软件测试的效率和覆盖率。
|
1月前
|
JavaScript 前端开发 UED
Vue执行流程及渲染解析
【10月更文挑战第5天】
|
1月前
|
存储 搜索推荐 数据库
运用LangChain赋能企业规章制度制定:深入解析Retrieval-Augmented Generation(RAG)技术如何革新内部管理文件起草流程,实现高效合规与个性化定制的完美结合——实战指南与代码示例全面呈现
【10月更文挑战第3天】构建公司规章制度时,需融合业务实际与管理理论,制定合规且促发展的规则体系。尤其在数字化转型背景下,利用LangChain框架中的RAG技术,可提升规章制定效率与质量。通过Chroma向量数据库存储规章制度文本,并使用OpenAI Embeddings处理文本向量化,将现有文档转换后插入数据库。基于此,构建RAG生成器,根据输入问题检索信息并生成规章制度草案,加快更新速度并确保内容准确,灵活应对法律与业务变化,提高管理效率。此方法结合了先进的人工智能技术,展现了未来规章制度制定的新方向。
34 3
|
1月前
|
人工智能 缓存 Java
深入解析Spring AI框架:在Java应用中实现智能化交互的关键
【10月更文挑战第12天】Spring AI 是 Spring 框架家族的新成员,旨在满足 Java 应用程序对人工智能集成的需求。它支持自然语言处理、图像识别等多种 AI 技术,并提供与云服务(如 OpenAI、Azure Cognitive Services)及本地模型的无缝集成。通过简单的配置和编码,开发者可轻松实现 AI 功能,同时应对模型切换、数据安全及性能优化等挑战。
103 3
|
1月前
|
存储 缓存 边缘计算
揭秘直播带货背后的黑科技:播放流程全解析!
大家好,我是小米,今天聊聊社区直播带货的技术细节。我们将探讨直播播放流程中的关键技术,包括 HTTP DASH 协议、POP(Point of Presence)缓存和一致性哈希算法等。通过这些技术,直播流能根据网络状况动态调整清晰度,保证流畅体验。POP 和 DC 的多层次缓存设计减少了延迟,提升了观看效果。无论是技术人员还是直播运营者,都能从中受益。希望通过本文,你能更好地理解直播背后的技术原理。
46 3
|
1月前
|
分布式计算 Java 应用服务中间件
NettyIO框架的深度技术解析与实战
【10月更文挑战第13天】Netty是一个异步事件驱动的网络应用程序框架,由JBOSS提供,现已成为Github上的独立项目。
38 0

推荐镜像

更多