SpringBoot使用dynamic配置多数据源时使用@Transactional事务在非primary的数据源上遇到的问题

情景

  • Springboot项目中使用dynamic配置了多个数据源;
  • primary(主要)数据源是oracle;
  • 其他数据源有postgres;
  • 想要在非primary数据源中使用@Transactional进行事务管理;
  • 在这之前没有单独配置Transactional事务的bean。

出现的问题

  • 非primary数据源中事务的sql检查报错

原因

使用primary数据源的数据库(oracle)方言去检查非primary数据源的数据库(Postgresql)的sql语句,出现sql语法不兼容的情况;

解决方法:

如果使用了springboot dynamic 多数据源配置时,primary数据源和其他数据原的数据库类型不一致,但是还想要在非primary数据源中使用@Transactional事务

  • 使用自定义的transactionManager

    java 复制代码
    @Configuration
    public class TransactionManagerConfig {
    
        @Autowired
        private DataSource dataSource; // 动态数据源
    
        @Bean("db1TransactionManager")
        public DataSourceTransactionManager jiaoyiTransactionManager() {
            DynamicRoutingDataSource dynamicDataSource = (DynamicRoutingDataSource) dataSource;
            DataSource jiaoyiDataSource = dynamicDataSource.getDataSource("db1");
            return new DataSourceTransactionManager(jiaoyiDataSource);
        }
    
        @Bean("db2TransactionManager")
        public DataSourceTransactionManager clearingTransactionManager() {
            DynamicRoutingDataSource dynamicDataSource = (DynamicRoutingDataSource) dataSource;
            DataSource clearingDataSource = dynamicDataSource.getDataSource("db2");
            return new DataSourceTransactionManager(clearingDataSource);
        }
    }
  • 在服务中使用

    java 复制代码
    @Service
    public class MultiDataSourceService {
    
        @Autowired
        private Db1Mapper db1Mapper;
    
        @Autowired
        private Db2Mapper db2Mapper;
    
        // 使用db1数据源的事务
        @Transactional("db1TransactionManager")
        public void processJiaoyi() {
            db1Mapper.insertData();
        }
    
        // 使用db2数据源的事务
        @Transactional("db2TransactionManager")
        public void processClearing() {
            db2Mapper.updateData();
        }
    }

注意事项

  • 数据源切换与事务顺序: 确保@DS注解与@Transactional在同一方法或调用链中,避免数据源切换与事务管理器不匹配。
相关推荐
爱笑的眼睛114 小时前
FastAPI 路由系统深度探索:超越基础 CRUD 的高级模式与架构实践
java·人工智能·python·ai
武子康4 小时前
Java-193 Spymemcached 深入解析:线程模型、Sharding 与序列化实践全拆解
java·开发语言·redis·缓存·系统架构·memcached·guava
韩凡5 小时前
HashMap的理解与结构
java·开发语言·哈希算法
hhzz5 小时前
Spring Boot整合Activiti的项目中实现抄送功能
java·spring boot·后端
初心灬5 小时前
Java 对接coze工作流
java
愿你天黑有灯下雨有伞5 小时前
实战演练:如何在Spring Boot项目中优雅地使用参数校验
spring boot
代衡_Monster5 小时前
通过位运算实现Java逻辑的包含关系
java·java-ee
毕设源码-朱学姐5 小时前
【开题答辩全过程】以 基于Java的失物招领系统设计与实现为例,包含答辩的问题和答案
java·开发语言
清晓粼溪5 小时前
统一异常处理
java·开发语言
TH_16 小时前
4、前台界面,表格列名写错
java