Java开发日志-双数据库事务问题

这里在yaml配置了两个远程数据库

复制代码
spring:
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    druid:
      # 主库数据源
      master:
        driverClassName: com.mysql.cj.jdbc.Driver
        url: xxxx
        username: DB1
      # 从库数据源
      slave:
        enabled: true
        driverClassName: com.mysql.cj.jdbc.Driver
        url: xx
        username: DB2

当我在Service业务类(关联的主数据库中的表)中需要调用从库的Service业务时,

类似于下边这种情况

java 复制代码
@Transactional
public class 主库Service{

    @Autowired
    private 从库Service 从库Service;

    public void xxx() {
       Long id = 从库Service.selectPurchasePriceListVOById(id);
    }
}

这里在调用从库Service函数想要获取ID时,会报错返回无法找到对应的数据表(从库开关正常打开状态)就是找不到对应的数据表。

临时解决方案:(从Controller层进行调用)如下

java 复制代码
public class xxController extends BaseController
{
    @Autowired
    private 从库Service 从库Service;

    @Autowired
    private 主库Service 主库Service;

    public viod xxx(){
        Long id = 从库Service.getId();
        主库Service.xxx(id);
    }
    
}

分析问题:因为主Service添加了事务,导致从库的Service无法进行切换从库,目前解决方案就是不在有事务的业务类中进行主从库切换。

相关推荐
猫的玖月6 小时前
(一)MY SQL概述
数据库·sql
昇腾CANN6 小时前
TileLang-Ascend 算子性能优化方法与实操
开发语言·javascript·性能优化·昇腾·cann
沐知全栈开发6 小时前
ionic 手势事件详解
开发语言
lsx2024067 小时前
Bootstrap 按钮
开发语言
脑子进水养啥鱼?7 小时前
PostgreSQL .history 文件
数据库·postgresql
qinqinzhang7 小时前
Java 中的 IoC、AOP、MVC
java
神仙别闹7 小时前
基于 Python 实现 BERT 的情感分析模型
开发语言·python·bert
禾叙_7 小时前
【langchain4j】结构化输出(六)
java·开发语言
NQBJT7 小时前
VS Code配置Python人工智能开发环境
开发语言·人工智能·vscode·python
饭小猿人7 小时前
Android 腾讯X5WebView如何禁止系统自带剪切板和自定义剪切板视图
android·java