有時,在一個項目中會用到多數據源,此時可以使用苞米豆的dynamic-datasource-spring-boot-starter
:
首先,引入jar
包:
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>dynamic-datasource-spring-boot-starter</artifactId>
<version>2.5.4</version>
</dependency>
然后,在Springboot
的application.yml
中進行配置:
spring:
datasource:
url: jdbc:mysql://localhost:3306/test2?serverTimezone=UTC&useUnicode=true&characterEncoding=utf8
driver-class-name: com.mysql.cj.jdbc.Driver
username: root
password: root
dynamic:
primary: master
datasource:
master:
url: jdbc:mysql://localhost:3306/test2?serverTimezone=UTC&useUnicode=true&characterEncoding=utf8
driver-class-name: com.mysql.cj.jdbc.Driver
username: root
password: root
sub:
url: jdbc:mysql://localhost:3306/test2?serverTimezone=UTC&useUnicode=true&characterEncoding=utf8
driver-class-name: com.mysql.cj.jdbc.Driver
username: root1
password: root1
其中配置了兩個數據源,master
與sub
,其中選擇master
作為默認數據源(對應primary
配置);
若想使用sub
作為部分代碼的數據源,可在ServiceImpl
做如下配置:
@DS("sub")
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {}
在使用@DS
注解時,有如下注意事項:
- 不能使用事務,否則數據源不會切換,使用的還是第一次加載的數據源;
- 第一次加載數據源之后,第二次、第三次…操作其它數據源,如果數據源不存在,使用的還是第一次加載的數據源;
- 數據源名稱不要包含下划線,否則不能切換。