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

本文介绍了如何在Spring Boot中配置Activiti工作流,包括创建配置文件,设置数据源,以及流程引擎的创建。详细阐述了配置文件中的关键细节,如数据库连接和schema更新。此外,还讲解了Log4j配置,以及通过代码生成流程表结构的过程。文章最后列出了Activiti工作流涉及的主要数据库表及其作用。
摘要由CSDN通过智能技术生成

创建配置文件

<?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系统架构图

 ProcessEngin引擎接口

 

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

前提条件是

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();
    }
	

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值