天天看点

activiti7工作流引擎之创建流程模型表结构

创建配置文件

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:tx="http://www.springframework.org/schema/tx"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
						http://www.springframework.org/schema/contex http://www.springframework.org/schema/context/spring-context.xsd
						http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd">

    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver" />
        <property name="url" value="jdbc:mysql://localhost:3306/activiti?useSSL=false" />
        <property name="username" value="root" />
        <property name="password" value="123456" />
        <property name="maxActive" value="3" />
        <property name="maxIdle" value="1" />
    </bean>

    <bean id="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration">
        <property name="dataSource" ref="dataSource"></property>
        <property name="databaseSchemaUpdate" value="true"/>
    </bean>
</beans>
           

细节注释

细节一:StandloneProcessEngineConfiguration中需要注入数据源。

细节二:StandloneProcessEngineConfiguration中属性为databaseSchemaUpdate属性值设置为true

指的是:容器启动时如果数据库中存在某个表就不在创建已存在的表结构,如果不存在则创建不存在的表结构。

细节三:StandloneProcessEngineConfiguration中id的名称是processEngineConfiguration不能改变,如果改变启动会报错。

细节四:中文名称保存乱码问题(在xml配置数据源是&要进行转义&amp;)

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
             <property name="url" value="jdbc:mysql://localhost:3306/activiti? 
                useSSL=false&amp;useUnicode=true&amp;characterEncoding=utf8" />
    </bean>
           

创建log4j.perperties

# Set root category priority to INFO and its only appender to CONSOLE.
#log4j.rootCategory=INFO, CONSOLE            debug   info   warn error fatal
log4j.rootCategory=debug, CONSOLE, LOGFILE

# Set the enterprise logger category to FATAL and its only appender to CONSOLE.
log4j.logger.org.apache.axis.enterprise=FATAL, CONSOLE

# CONSOLE is set to be a ConsoleAppender using a PatternLayout.
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=%d{ISO8601} %-6r [%15.15t] %-5p %30.30c %x - %m\n

# LOGFILE is set to be a File appender using a PatternLayout.
log4j.appender.LOGFILE=org.apache.log4j.FileAppender
log4j.appender.LOGFILE.File=d:\axis.log
log4j.appender.LOGFILE.Append=true
log4j.appender.LOGFILE.layout=org.apache.log4j.PatternLayout
log4j.appender.LOGFILE.layout.ConversionPattern=%d{ISO8601} %-6r [%15.15t] %-5p %30.30c %x - %m\n

           

生成流程表结构

(springBoot可以通过编写自动配置类)

第一步:加载流程配置文件,创建流程配置对象

ProcessEnginConfiguration.createProcessConfigurationResource
           

第二步:通过流程配置对象,创建流程引擎

package org.wxy.com.activiti;

import org.activiti.engine.ProcessEngine;
import org.activiti.engine.ProcessEngineConfiguration;
import org.junit.Test;

/**
 * Unit test for simple App.
 */
public class AppTest {
	
	@Test
	public  void testprocess(){
	    //加载配置文件创建工作流程配置对象
		//如果使用avtiviti默认的idprocessEngineConfiguration
		ProcessEngineConfiguration processEngineConfiguration = ProcessEngineConfiguration.createProcessEngineConfigurationFromResource("activiti.cfg.xml");
		//如果修改了avtiviti默认的id时
		//ProcessEngineConfiguration.createProcessEngineConfigurationFromResource("activiti.cfg.xml","修改的id");
		//创建工作流程引擎
		ProcessEngine processEngine = processEngineConfiguration.buildProcessEngine();
    }
}
           

第三步:运行后数据库,就会生成工作引擎相关表结构

表结构参考:https://blog.csdn.net/hj7jay/article/details/51302829

数据库流程表结构说明

 Activiti工作流所有的表名默认以“ACT_”开头并且表名的第二部分用两个字母表明表的用例,而这个用例也基本上跟Service API匹配。

  •  ACT_GE_* : “GE”代表“General”(通用),用在各种情况下;
  •  ACT_HI_* : “HI”代表“History”(历史),记录历史数据,比如执行过的流程实例、变量、任务等等。、

  Activit默认提供了4种历史级别:

  none: 不保存任何历史记录,可以提高系统性能;

 activity:保存所有的流程实例、任务、活动信息;

 audit:也是Activiti的默认级别,保存所有的流程实例、任务、活动、表单属性;

 full:最完整的历史记录,除了包含audit级别的信息之外还能保存详细,例如:流程变量。

       对于几种级别根据对功能的要求选择,如果需要日后跟踪详细可以开启full。

  • ACT_ID_* : “ID”代表“Identity”(身份),这些表中保存的都是身份信息,如用户和组以及两者之间的关系。如果Activiti被集成在某一系统当中的话,这些表可以不用,可以直接使用现有系统中的用户或组信息;
  • ACT_RE_* : “RE”代表“Repository”(仓库),这些表中保存一些‘静态’信息,如流程定义和流程资源(如图片、规则等);
  • ACT_RU_* : “RU”代表“Runtime”(运行时),这些表中保存一些流程实例、用户任务、变量等的运行时数据。Activiti只保存流程实例在执行过程中的运行时数据,并且当流程结束后会立即移除这些数据,这是为了保证运行时表尽量的小并运行的足够快;

 数据库流程表结构清单

表分类 表名 解释
一般数据 ACT_GE_BYTEARRAY 通用的流程定义和流程资源
ACT_GE_PROPERTY 系统相关属性
流程历史记录 ACT_HI_ACTINST 历史的流程实例
ACT_HI_ATTACHMENT 历史的流程附件
ACT_HI_COMMENT 历史的说明性信息
ACT_HI_DETAIL 历史的流程运行中的细节信息
ACT_HI_IDENTITYLINK 历史的流程运行过程中用户关系
ACT_HI_PROCINST 历史的流程实例
ACT_HI_TASKINST 历史的任务实例
ACT_HI_VARINST 历史的流程运行中的变量信息
用户用户组表 ACT_ID_GROUP 身份信息-组信息
ACT_ID_INFO 身份信息-组信息
ACT_ID_MEMBERSHIP 身份信息-用户和组关系的中间表
ACT_ID_USER 身份信息-用户信息
流程定义表 ACT_RE_DEPLOYMENT 部署单元信息
ACT_RE_MODEL 模型信息
ACT_RE_PROCDEF 已部署的流程定义
运行实例表 ACT_RU_EVENT_SUBSCR 运行时事件
ACT_RU_EXECUTION 运行时流程执行实例
ACT_RU_IDENTITYLINK 运行时用户关系信息
ACT_RU_JOB 运行时作业
ACT_RU_TASK 运行时任务
ACT_RU_VARIABLE 运行时变量表

Activity系统架构图

activiti7工作流引擎之创建流程模型表结构

 ProcessEngin引擎接口

activiti7工作流引擎之创建流程模型表结构

注:简单的方式生成工作流的表结构

前提条件是

1.配置文件名称必须是avtiviti.cfg.xml

2.  <bean id="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration"> id的名称必须是    processEngineConfiguration

@Test
	public  void testprocess2(){
		//直接生成工作流引擎的25张表
		ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
    }
	
           

继续阅读