一、Mybatis配置多数据源
前面讲了Mybatis配置多数据源配置的包路径分库方式——SpringBoot系列:Spring Boot多数据源,Mybatis方式,这种方式实现多数据源,以包区分,清晰明了,但是很多时候会造成很多代码冗余,比如举例中的userDao,而且新增包需要去修改配置文件。实际中一般并不采用这种方式,而是使用aop,这次就来讲解aop实现动态多数据源。
aop实现多数据源,在pom依赖上,多添加aop的依赖。这个很好理解,没有aop依赖还怎么使用aop。
<!--mysql连接-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<!--druid连接池-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.1.10</version>
</dependency>
<!--mybatis依赖-->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.2</version>
</dependency>
<!--aop依赖-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
application配置文件方面并没有太大差别,依旧配置多个数据源即可。
server:
port: 10900
spring:
datasource:
master:
# 新版驱动从com.mysql.jdbc.Driver变更为com.mysql.cj.jdbc.Driver
driver-class-name: com.mysql.cj.jdbc.Driver
# 数据源需要添加时间标准和指定编码格式解决乱码 You