springboot整合mybatisplus配置多数据源

75 篇文章 719 订阅 ¥19.90 ¥99.00
47 篇文章 15 订阅 ¥19.90 ¥99.00

前言

业务中,有一个需求,需要定时将一个库的部分业务表的数据同步到另一个库中,由于在现有的项目中进行改造比较麻烦,因此索性使用springboot和mybatisplus完成一个多数据源的环境搭建

简单说明一下,使用mybatis也是可以的,但项目中有技术要求,同时使用过mybatisplus之后,发现功能更加强大,而且使用很灵活,因此就选择了这个组件

搭建流程

开发步骤:

  • 新建springboot项目。
  • 导入依赖 --> devtools,lombok,web,thymeleaf,mysql,aop,mybatisplus,druid,swagger。
  • maven多环境配置。
  • 编写application.yml --> 项目端口,项目路径名,mybatisplus配置,mysql多数据源配置。
  • 新建DataSourceContextHolder 用于设置,获取,清空 当前线程内的数据源变量。
  • 新建 MultipleDataSource 实现 AbstractRoutingDataSource 类。重写determineCurrentLookupKey(),通过DataSourceContextHolder 获取数据源变量,用于当作lookupKey取出指定的数据源。
  • 新建DataSourceEnum 用于存放数据源名称。
  • 新建注解 DataSource,用于aop类中当作切入点来选择数据源。
  • 编写aop类 --> DataSourceAspect.java
  • 5
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 7
    评论
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 环境,请相应调整配置方式。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小码农叔叔

谢谢鼓励

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值