当前位置: 首页 > news >正文

Activiti兼容达梦数据库

1. 自定义类继承SpringProcessEngineConfiguration类,重写initDatabaseType方法。
package com.ydtf.cbda.module.cbdacim.improcess.config;import org.activiti.engine.ActivitiException;
import org.activiti.spring.SpringProcessEngineConfiguration;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.SQLException;/*** @author 自定义activiti的数据库连接* @date 2023/9/14 14:31*/
public class CustomConnectionSpringProcessEngineConfiguration extends SpringProcessEngineConfiguration {private static Logger log = LoggerFactory.getLogger(CustomConnectionSpringProcessEngineConfiguration.class);@Overridepublic void initDatabaseType() {Connection connection = null;try {connection = this.dataSource.getConnection();DatabaseMetaData databaseMetaData = connection.getMetaData();String databaseProductName = databaseMetaData.getDatabaseProductName();log.debug("database product name: '{}'", databaseProductName);this.databaseType = databaseTypeMappings.getProperty(databaseProductName);if (databaseProductName.contains("DM DBMS")) {databaseProductName = "Oracle";}databaseType = databaseTypeMappings.getProperty(databaseProductName);if (this.databaseType == null) {throw new ActivitiException("couldn't deduct database type from database product name '" + databaseProductName + "'");}log.debug("using database type: {}", this.databaseType);if ("mssql".equals(this.databaseType)) {this.maxNrOfStatementsInBulkInsert = this.DEFAULT_MAX_NR_OF_STATEMENTS_BULK_INSERT_SQL_SERVER;}} catch (SQLException var12) {log.error("Exception while initializing Database connection", var12);} finally {try {if (connection != null) {connection.close();}} catch (SQLException var11) {log.error("Exception while closing the Database connection", var11);}}}
}
2.  修改Activiti启动项配置
package com.ydtf.cbda.module.cbdacim.improcess.config;import org.activiti.spring.SpringProcessEngineConfiguration;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.core.task.TaskExecutor;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
import org.springframework.transaction.PlatformTransactionManager;import javax.sql.DataSource;/*** @author 修改activiti启动配置项* @date 2023/9/14 14:38*/
@Configuration
public class ActivitiConfigguration {@Autowiredprivate DataSource dataSource;@Autowiredprivate PlatformTransactionManager transactionManager;@Beanpublic SpringProcessEngineConfiguration getProcessEngineConfiguration() {SpringProcessEngineConfiguration configuration = new CustomConnectionSpringProcessEngineConfiguration();configuration.setDataSource(dataSource);configuration.setTransactionManager(transactionManager);configuration.setDatabaseSchemaUpdate("true");return configuration;}@Bean@Primarypublic TaskExecutor primaryTaskExecutor(){return new ThreadPoolTaskExecutor();}
}
http://www.lryc.cn/news/167678.html

相关文章:

  • shell 流程控制
  • 【C++】红黑树插入操作实现以及验证红黑树是否正确
  • 学信息系统项目管理师第4版系列07_项目管理知识体系
  • Leetcode 2851. String Transformation
  • 在PHP8中对数组进行计算-PHP8知识详解
  • Android BottomSheetDialog最大展开高度问题
  • 记录Linux部署人脸修复GFPGAN项目Docker Python 使用
  • 如何编写可重入的函数?
  • 使用纯C语言定义通用型数据结构的方法和示例
  • 数据结构基础8:二叉树oj+层序遍历。
  • Spring注解家族介绍:@RestController
  • rocketmq
  • JAVA成员变量首字母小写,第二个字母大写报错问题(原因:Lombok与Spring冲突)
  • Python入门教程 |Python 错误和异常
  • API商品接口对接使用:从理论到实践
  • 解决stable diffusion webui1.6 wd1.4 tagger加载失败的问题
  • Python学习-实现简单的http服务
  • #循循渐进学51单片机#变量进阶与点阵LED#not.6
  • 访问者模式
  • epoll 的实现
  • 怎么用excel管理固定资产
  • 记录crack某IDE插件过程
  • Android DEX相关,ART加载OAT文件
  • laravel框架 - 安装初步使用学习 composer安装
  • API实战教程:使用身份证OCR识别API构建一个应用
  • 前端-layui动态渲染表格行列与复杂表头合并
  • IDM(Internet Download Manager)下载器2024最新版本如何下载?
  • 前端综合练手小项目
  • 接口优化1
  • 【无公网IP内网穿透】 搭建Emby媒体库服务器并远程访问「家庭私人影院」