@DS注解的使用,動態數據源,事務 -九五小龐


有時,在一個項目中會用到多數據源,此時可以使用苞米豆的dynamic-datasource-spring-boot-starter
首先,引入jar包:

<dependency>
<groupId>com.baomidou</groupId>
<artifactId>dynamic-datasource-spring-boot-starter</artifactId>
<version>2.5.4</version>
</dependency>
然后,在Springbootapplication.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

 


其中配置了兩個數據源,mastersub,其中選擇master作為默認數據源(對應primary配置);
若想使用sub作為部分代碼的數據源,可在ServiceImpl做如下配置:

 

@DS("sub")

@Service

public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {}

 

 

在使用@DS注解時,有如下注意事項:

  1. 不能使用事務,否則數據源不會切換,使用的還是第一次加載的數據源;
  2. 第一次加載數據源之后,第二次、第三次…操作其它數據源,如果數據源不存在,使用的還是第一次加載的數據源;
  3. 數據源名稱不要包含下划線,否則不能切換。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM