博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
activiti 数据库升级 upgrade
阅读量:6159 次
发布时间:2019-06-21

本文共 3907 字,大约阅读时间需要 13 分钟。

分享牛原创(尊重原创 转载对的时候第一行请注明,转载出处来自http://blog.csdn.net/qq_30739519)

在项目中我们如果使用activiti 工作流引擎的时候,肯定是需要数据库支持的,如果有一天我们打算升级activiti 工作流引擎的时候,那么对应的数据库表或者视图也是需要升级,因为有可能表结构有调整,举例:activiti 5.14的时候act_re_deployment表中没有tenant_id_字段,activiti 5.19有这个字段了,那我们升级的时候,肯定需要升级数据库了,下面详细的讲解如何升级数据库。

1.1.1. 第一种方式 手动sql方式

我们首先打开我们下载的activiti 工程,目录结构如下所示:

 

 

打开database目录,结构如下图所示:

 

目录说明:

create 数据库、表视图、索引的创建脚本。

drop 数据库、表视图、索引的删除脚本。(删除引擎最好这种方式删除的比较干净)

upgrade 数据库、表视图、索引的升级脚本。

目录里面的sql命名规范:

activiti.db2.create.history.sql

activiti:activiti工作流的标示。

db2 数据库厂商的名称(可以是mysqlh2oraclepostgres)比如我用的是postgres数据库,那么操作的时候选择activiti.postgres开头的即可。

create:创建数据库的意思,那对应的肯定有dropupgradestep标示符,操作的时候选择对应的即可。

最后一个标示符history,因为sql创建表的时候分为三个大的sql脚本。

1.engine核心的创建表语句、主要是ru*表等。

2.history 主要创建工作流的hi*表。

3.identity 主要创建工作流的用户表、id*以及用户信息表(扩展表的时候可以不使用这个,后面权限构建章节会详细讲解)

 

上面对目录做了一个介绍,接下来就进入upgrade目录中,如下图所示是upgrade表中的部分sql脚本:

 

升级数据库的时候比如说53to.43.xx.sqll升级的时候 53代表当前的activiti 版本,54标示需要升级到的版本。选择需要升级的数据库表的sql对应版本即可。

activiti对应的版本信息如下:

 

 

1.1.2. 第二种方式 配置方式

//主要是配置activiti 工作流引擎自定义的一些属性信息。

property name="databaseSchemaUpdate" value="drop-create">

这里说明一下我们使用的主要的工作流对象是processEngine,从这个对象中获取各个xxxService,processEngine是需要processEngineConfiguration对象中的属性的,就好比你你去找工作,总要把自己的属性提升提升吧,换换衣服,刮刮胡子之类的。

我们接下来重点看一下ProcessEngineImpl中的源码。主要看是数据库创建、删除、更新操作底层是如何实现的。

ProcessEngineImpl继承关系如下图所示:

 

ProcessEngineImpl类的构造方法如下:

public ProcessEngineImpl(ProcessEngineConfigurationImpl processEngineConfiguration) {...commandExecutor.execute(processEngineConfiguration.getSchemaCommandConfig(), new SchemaOperationsProcessEngineBuild());...}

下面我们重点看一下commandExecutor.execute(processEngineConfiguration.getSchemaCommandConfig(), new SchemaOperationsProcessEngineBuild());方法,这个方法就是进行数据库表的创建、更新以及删除操作。看看这个方法是怎么获取配置文件然后操作数据库的,我们不仅要知道怎么配置,更重要的是知道配置在activiti中是如何解析使用的。

 

//这是一个典型的命令模式,这里我们先看一下这个SchemaOperationsProcessEngineBuild 命令是如何使用的,关于activiti Command 模式我们会在后面的文章详细的讲解

public final class SchemaOperationsProcessEngineBuild implements Command {  public Object execute(CommandContext commandContext) {    commandContext      .getSession(DbSqlSession.class)      .performSchemaOperationsProcessEngineBuild();    return null;  }}

下面看一下performSchemaOperationsProcessEngineBuild方法中的操作:

打开类org.activiti.engine.impl.db.DbSqlSession中的performSchemaOperationsProcessEngineBuild方法如下所示:

public static final String DB_SCHEMA_UPDATE_CREATE = "create";public static final String DB_SCHEMA_UPDATE_DROP_CREATE = "drop-create";public void performSchemaOperationsProcessEngineBuild() {//这个方法就是获取 上面的
property name="databaseSchemaUpdate" value="drop-create">
中的配置的信息 默认不配置 是falseString databaseSchemaUpdate = Context.getProcessEngineConfiguration().getDatabaseSchemaUpdate();//drop-create 删除表重新创建 if (ProcessEngineConfigurationImpl.DB_SCHEMA_UPDATE_DROP_CREATE.equals(databaseSchemaUpdate)) { try {//删除操作 dbSchemaDrop(); } catch (RuntimeException e) { // ignore }}//配置的是 create-drop drop-create create三个中的任意一个 if ( org.activiti.engine.ProcessEngineConfiguration.DB_SCHEMA_UPDATE_CREATE_DROP.equals(databaseSchemaUpdate) || ProcessEngineConfigurationImpl.DB_SCHEMA_UPDATE_DROP_CREATE.equals(databaseSchemaUpdate) || ProcessEngineConfigurationImpl.DB_SCHEMA_UPDATE_CREATE.equals(databaseSchemaUpdate) ) {//创建操作 dbSchemaCreate(); } else if (org.activiti.engine.ProcessEngineConfiguration.DB_SCHEMA_UPDATE_FALSE.equals(databaseSchemaUpdate)) {//检查版本 dbSchemaCheckVersion(); } else if (ProcessEngineConfiguration.DB_SCHEMA_UPDATE_TRUE.equals(databaseSchemaUpdate)) {//设置true就更新操作 dbSchemaUpdate(); } }

这个时候我们已经很明确参数配置的含义,以及配置参数后引擎的处理。关于activiti 工作流引擎中如何打开数据库操作表、如何更新表,因为这个地方比较负责设计mybstis内容,这个也在后面的章节讲解,然后举一反三的把这个原理也说一下。

最后,我们总结一下两种方式的优缺点:

1.第一种方式最好,sql直接运行,在数据库层面操作,速度比较快。

2.第二种方式,需要配置,是在程序级别操作,肯定还需要打开数据库连接操作,如果打开数据库连接则比较消耗性能。如果自己扩展了activti 工作流的表,可能会引起不必要的麻烦。

3.个人推荐使用第一种直接运行sql的方式进行升级。

你可能感兴趣的文章
登记申请汇总
查看>>
Android Jni调用浅述
查看>>
CodeCombat森林关卡Python代码
查看>>
(二)Spring Boot 起步入门(翻译自Spring Boot官方教程文档)1.5.9.RELEASE
查看>>
Shell基础之-正则表达式
查看>>
JavaScript异步之Generator、async、await
查看>>
讲讲吸顶效果与react-sticky
查看>>
c++面向对象的一些问题1 0
查看>>
售前工程师的成长---一个老员工的经验之谈
查看>>
Get到的优秀博客网址
查看>>
老男孩教育每日一题-第107天-简述你对***的理解,常见的有哪几种?
查看>>
Python学习--time
查看>>
在OSCHINA上的第一篇博文,以后好好学习吧
查看>>
Spring常用注解
查看>>
linux:yum和apt-get的区别
查看>>
Sentinel 1.5.0 正式发布,引入 Reactive 支持
查看>>
数据库之MySQL
查看>>
2019/1/15 批量删除数据库相关数据
查看>>
数据类型的一些方法
查看>>
Webpack 2 中一些常见的优化措施
查看>>