mybatisplus-多数据源配置

1. 流程

  1. pom文件
  2. yml配置多数据源
  3. 具体服务添加注解@DS(“***”)

1.pom文件


        <!--mybatis plus 起步依赖-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.4.0</version>
        </dependency>


        <!--多数据源-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>dynamic-datasource-spring-boot-starter</artifactId>
            <version>3.5.2</version>
        </dependency>

2. yml配置

根据具体情况配置不同数据源…不同的数据库.不同sql源.都是可以的
官网链接


# datasource
spring:
  datasource:
    dynamic:
      primary: master #设置默认的数据源或者数据源组,默认值即为master
      strict: false #严格匹配数据源,默认false. true未匹配到指定数据源时抛异常,false使用默认数据源
      datasource:
        db_qa_wecom_datasync:   # 数据库1
          driver-class-name: org.postgresql.Driver
          url: jdbc:postgresql://127.0.0.1:5433/db_qa_wecom_datasync?currentSchema=public&autoReconnect=true&failOverReadOnly=false
          username: postgres
          password: root
        db_qa_wecom:   # 数据库2
          driver-class-name: org.postgresql.Driver
          url: jdbc:postgresql://127.0.0.1:5433/db_qa_wecom?currentSchema=public&autoReconnect=true&failOverReadOnly=false
          username: postgres
          password: root


3. 具体服务添加注解@DS(“***”)

3.1库表信息

在这里插入图片描述

3.2具体服务对应具体

在这里插入图片描述

3.3从不同的数据库中查询的结果.

在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis-Plus 中配置多数据源可以通过以下步骤完成: 1. 添加相关依赖:首先,在项目的 `pom.xml` 文件中添加 MyBatis-Plus 和数据库驱动的依赖。例如,如果你使用的是 MySQL 数据库,可以添加如下依赖: ```xml <dependencies> <!-- MyBatis-Plus --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>最新版本</version> </dependency> <!-- MySQL 驱动 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>最新版本</version> </dependency> </dependencies> ``` 2. 配置数据源:在项目的配置文件(例如 `application.yml` 或 `application.properties`)中,配置多个数据源的连接信息。每个数据源需要指定其对应的数据库驱动、URL、用户名和密码。例如: ```yaml spring: datasource: # 默认数据源配置 url: jdbc:mysql://localhost:3306/db1 username: root password: password # 第二个数据源配置 datasource2: url: jdbc:mysql://localhost:3306/db2 username: root password: password ``` 3. 配置多数据源:在配置类中,使用 `@Configuration` 注解标记该类为配置类,并使用 `@EnableTransactionManagement` 注解开启事务管理。然后,通过 `@Bean` 注解创建多个数据源,并将它们注入到 `DataSource` 类中。例如: ```java @Configuration @EnableTransactionManagement public class DataSourceConfig { @Bean @ConfigurationProperties("spring.datasource") public DataSource dataSource() { return new DruidDataSource(); } @Bean @ConfigurationProperties("spring.datasource.datasource2") public DataSource dataSource2() { return new DruidDataSource(); } } ``` 4. 配置 MyBatis-Plus:在配置类中,使用 `@MapperScan` 注解指定要扫描的 Mapper 接口的包路径,并在 `SqlSessionFactory` 上配置多个数据源。例如: ```java @Configuration @MapperScan(basePackages = "com.example.mapper") public class MybatisPlusConfig { @Autowired private DataSource dataSource; @Autowired private DataSource dataSource2; @Bean public SqlSessionFactory sqlSessionFactory() throws Exception { MybatisSqlSessionFactoryBean sqlSessionFactory = new MybatisSqlSessionFactoryBean(); sqlSessionFactory.setDataSource(dataSource); // 配置多数据源 MybatisConfiguration configuration = new MybatisConfiguration(); MapperRegistry mapperRegistry = new MapperRegistry(configuration); mapperRegistry.setKnownMappers(Collections.singletonList(BaseMapper.class)); sqlSessionFactory.setMapperRegistry(mapperRegistry); // 添加第二个数据源 SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean(); factoryBean.setDataSource(dataSource2); factoryBean.setConfiguration(configuration); return sqlSessionFactory.getObject(); } } ``` 以上就是在 MyBatis-Plus 中配置多数据源的步骤。配置完成后,你可以在需要使用特定数据源的地方使用 `@Qualifier` 注解指定要使用的数据源。例如,在 Service 类中使用多数据源: ```java @Service public class UserService { @Autowired @Qualifier("dataSource2") private DataSource dataSource; // 其他方法... } ``` 请注意,以上示例中使用了 Druid 数据库连接池,你也可以根据自己的需求选择其他连接池。另外,示例中的配置是基于 Spring Boot 的,如果你使用的是其他框架或纯 Spring 环境,请相应调整配置方式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值