前面我们讲解了流程绘制,今天的话,我们要来部署流程定义,启动流程实例,查看任务以及完成任务;把一个最简单的HelloWorld流程用代码实现并且走完流程。
我们先建一个单元测试类HelloWorldProcess
首先第一步,我们要操作流程,必须获取流程引擎实例;
1 2 3 4 |
|
第二步,我们需要把前面我们绘制的流程定义图,部署下(底层是解析XML,然后把数据存到数据库的表中去);
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
第三步:我们要启动流程实例,这样一个流程才开始;
1 2 3 4 5 6 7 8 9 10 11 |
|
第四步:启动流程后,我们流程会走到helloWorld节点,我们来查看下"java1234_小锋"这个用户的任务;
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 |
|
第五步:我们来完成helloWorld节点任务,让流程走完;
1 2 3 4 5 6 7 8 |
|
OK,前面仅仅是走流程的代码,我们下面来细讲下原理,数据库的表发生了什么;
这里有个很重要的概念,流程定义和流程实例的关系。大家可以把流程定义和流程实例的关系,理解成类和对象的关系;
流程定义就是一个模版,流程实例就是通过模版搞出来的具体的可用的东西。
所以后面涉及到的流程定义id name;流程实例id name大家不要晕。先把关系搞清楚。其他的都简单;
OK 然后我们来运行deploy方法,部署流程定义,这时候我们的流程定义表会发生一些变化;
首先我先把整个过程涉及的表的展示出来
首先act_re_deployment 流程定义部署表,插入了一条数据;
然后act_re_prodef 流程定义表也会有插入一条数据;
这里有流程定义id name key version等重要信息;后面可以通过接口来获取这些数据;
还有一个act_ge_bytearray表 用来存资源信息;
我们可以看到,把两个资源文件都存了 包括名称 以及文件内容;
以上是部署流程定义 数据库表里发生的事情;
然后我们继续 ,下面来启动流程实例;
运行start方法;
启动流程,数据库流程运行表也会发生相应的变化;
首先是运行时流程任务表:act_ru_task;插入了一条任务数据;
这个表很重要,ID_是任务id 数据2504 PROC_INST_ID_是流程实例ID 2501 以及Name 创建时间等;
接下来是act_ru_execution 运行时流程执行表;
这里的话 存的流程执行相关信息;
接下来是act_ru_identitylink 是于执行主体相关信息表;
当然我们这里是用具体的用户去执行的,至于group组的概念,后面单独讲;
流程实例启动完,接下来就到了helloWorld任务节点;
我们这时候可以来查看下"Java1234_小锋"任务;
运行findTask方法,控制台输出;
1 2 3 4 5 6 7 8 |
|
说明这个用户有任务可以执行;
我们继续走流程 执行completeTask方法;
执行完后,流程其实就已经走完了。
这时候我们再运行findTask,啥都没有输入,已经没有任务了;
OK 流程执行完,数据库表会发生什么变化呢?
首先ru开头的运行时候所有表的数据都没了,因为现在流程都走完了。不需要那些数据了;
然后在hi开头的表里,存了不少数据,主要是用来归档查询用的;
act_hi_taskinst 历史流程实例任务表加了一条任务数据;
act_hi_procinst 历史流程实例实例表加了一条流程实例相关信息的数据(包括开始时间,结束时间等等信息);
act_hi_identitylink 历史流程实例参数者的表加了一条数据;
act_hi_actinst 历史活动节点表加了三条流程活动节点信息的数据(每个流程实例具体的执行活动节点的信息);