文档章节

扩展activiti删除ACT_HI_*历史表

cookqq
 cookqq
发布于 2013/03/27 09:19
字数 646
阅读 3560
收藏 1

本人博客开始迁移,博客整个架构自己搭建及编码 http://www.cookqq.com/listBlog.action 

activiti自带了很多表,如图:

ACT_HI_*:HI表示历史数据(History)表,包括过期的流程实例,过期的变量和过期的任务等。

历史表中没有创建外键,可以很好的控制历史表。

在项目中,有可能不需要保存历史记录,也就是这些ACT_HI_*表可以删除了。

删除ACT_HI_*历史表,重新启动项目后报错:

严重: Error while closing command context
org.activiti.engine.ActivitiException: Activiti database problem: Tables missing for component(s) history
	at org.activiti.engine.impl.db.DbSqlSession.dbSchemaCheckVersion(DbSqlSession.java:713)
	at org.activiti.engine.impl.db.DbSqlSession.performSchemaOperationsProcessEngineBuild(DbSqlSession.java:1097)
	at org.activiti.engine.impl.SchemaOperationsProcessEngineBuild.execute(SchemaOperationsProcessEngineBuild.java:27)
	at org.activiti.engine.impl.interceptor.CommandExecutorImpl.execute(CommandExecutorImpl.java:24)
	at org.activiti.engine.impl.interceptor.CommandContextInterceptor.execute(CommandContextInterceptor.java:60)
	at org.activiti.engine.impl.interceptor.LogInterceptor.execute(LogInterceptor.java:32)
	at org.activiti.engine.impl.ProcessEngineImpl.<init>(ProcessEngineImpl.java:75)
	at org.activiti.engine.impl.cfg.ProcessEngineConfigurationImpl.buildProcessEngine(ProcessEngineConfigurationImpl.java:311)
	at org.activiti.engine.ProcessEngines.buildProcessEngine(ProcessEngines.java:194)
	at org.activiti.engine.ProcessEngines.initProcessEnginFromResource(ProcessEngines.java:167)
	at org.activiti.engine.ProcessEngines.init(ProcessEngines.java:98)

定位到错误地方:DbSqlSession.java


 if (dbSqlSessionFactory.isDbHistoryUsed() && !isHistoryTablePresent()) {
        errorMessage = addMissingComponent(errorMessage, "history");
      }

这里主要的工作是检查数据库中是否有历史表,因为上面删除了数据库中的历史表所以报错了。


这里面有一个很重要的变量dbSqlSessionFactory.isDbHistoryUsed() ,从代码上面的意思也就是可以关闭使用历史表,好吧,就在创建配置文件的时候把它设置成false。

 ProcessEngineConfiguration configuration = ProcessEngineConfiguration
		    		.createProcessEngineConfigurationFromResourceDefault();
		  if(configuration instanceof ProcessEngineConfigurationImpl){
			  //这里的主要作用是为了,删除历史数据,在启动的时候不去检测历史数据库是否存在
			 ((ProcessEngineConfigurationImpl) configuration).setDbHistoryUsed(false);
		  }
		  ProcessEngine processEngine = configuration.buildProcessEngine();

重新启动后还是有问题,后来debug跟进去发现在使用:


ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();

使用上面代码获取引擎的时候又一次去加载配置文件了,搞了半天,才发现:


 ProcessEngines.getDefaultProcessEngine()获取默认的activiti引擎,首先会根据字段isInitialized判断是否已经加载了activiti配置文件,如果没有加载就去加载activiti.cfg.xml和activiti-context.xml,如果加载了,就在processEngines根据名称在获取相应的引擎。

使用 configuration.buildProcessEngine()创建activiti引擎的时候,加载了activiti配置文件,然后把创建的引擎添加到了工具类ProcessEngines的processEngines中。并没有设置字段isInitialized。

所以在项目中使用 ProcessEngines.getDefaultProcessEngine()获取默认的activiti引擎时候,第一次还会去加载配置文件信息。

这个怎么解决呢?

http://www.activiti.org/userguide/index.html 没有找到相应的信息。

后来想到activiti.cfg.xml中的配置信息需要加载到ProcessEngineConfigurationImpl中,应该是先解析,然后寻找相应属性的set方法进行赋值啊(我猜的)。那就通过配置文件设置吧:

<property name="dbHistoryUsed" value="false" />

启动后项目,成功了,不在报错了。







© 著作权归作者所有

cookqq

cookqq

粉丝 119
博文 268
码字总数 156096
作品 0
海淀
技术主管
私信 提问
加载中

评论(2)

cookqq
cookqq 博主

引用来自“thinkeee”的评论

请问下楼主用的activiti版本是多少?

5.12
thinkeee
thinkeee
请问下楼主用的activiti版本是多少?
Activiti工作流实战-3

数据库(先了解后看) Activiti数据库支持: Activiti的后台是有数据库的支持,所有的表都以ACT_开头。 第二部分是表示表的用途的两个字母标识。 用途也和服务的API对应。 ACTRE*: ‘RE’表示...

帅的不像男的
2016/07/01
301
0
Activiti 工作流学习 (三)

上一篇 Activiti 工作流学习(二) 都是在网上找的一些基本概念,引用的文档比较多比较杂,就不一一列出了。再此表示感谢。 关键对象 1. Deployment:流程部署对象,部署一个流程时创建。 2....

雷斯林
2016/12/10
411
0
activiti工作流数据库表详细介绍(23张表)

Activiti的后台是有数据库的支持,所有的表都以ACT_开头。 第二部分是表示表的用途的两个字母标识。 用途也和服务的API对应。 ACTRE*: 'RE'表示repository。 这个前缀的表包含了流程定义和流...

shanxi_liyong
2015/10/15
832
0
activiti开发笔记

actgebytearray 多个对1个 actredeployment 数据库说明: ACTRE* RE 表示 repository . 这个前缀表包含了流程定义 和流程静态资源(图片,规则等等) ACTRU* RU表示 runtime 这些运行时的表,...

之渊
2016/09/21
87
0
Activiti基础教程--01(简介、代码生成Activiti的25张表、Activiti配置文件activiti.cfg.xml生成25张表、在Eclipse上安装Activiti插件)

gihub:https://github.com/changwensir/Activiti/tree/master/ActivitiDemo1 一、简介 Activiti项目是一项新的基于Apache许可的开源BPM平台,从基础开始构建,旨在提供支持新的BPMN 2.0标准,...

xiaomin0322
2018/05/31
241
0

没有更多内容

加载失败,请刷新页面

加载更多

ZhaoWei-2020-01-18

Redis官方文档 简介 Redis是开源的(BSD许可)内存数据结构存储,用作数据库,缓存和消息代理。它支持数据结构,例如 字符串,哈希,列表,集合,带范围查询的排序集合,位图,超日志,带有半...

SuSheePark
20分钟前
11
0
替换字符串C#中的换行符

如何在C#中替换字符串中的换行符? #1楼 由于新行可以用\\n , \\r和\\r\\n分隔,因此我们首先将\\r和\\r\\n替换为\\n ,然后才拆分数据字符串。 以下几行应转到parseCSV方法: function p...

javail
22分钟前
6
0
快递物流上门取件api接口对接指南(中通圆通申通韵达百世)

1.常用快递API 支持顺丰、EMS、申通、圆通、韵达、汇通、中通、天天、德邦、全峰等主流快递公司。 上门取件,是电商平台为寄件用户提供的通过一键下单到快递员,并在2小时上门取件的寄件服务...

程序的小猿
26分钟前
6
0
WebFlux系列(十一)WebClient 日志

#Java#Spring#WebClient#WebFlux#log#日志# WebClient 日志 视频讲解 : https://www.bilibili.com/video/av83627944/ WebfluxConsumerApplication.java package com.example.webfluxconsumer......

潘文海
28分钟前
6
0
使用LINQ来获取一个List <>中的项目,而不是另一个List <>中的项目

我会假设有一个简单的LINQ查询可以做到这一点,但我不确定该如何做。 给出这段代码: class Program{ static void Main(string[] args) { List<Person> peopleList1 = new...

技术盛宴
37分钟前
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部