MyBatis-Plus 集成動態(tài)多數(shù)據(jù)源的實現(xiàn)示例
這里使用的是dynamic-datasource-spring-boot-starter ,它是一個基于springboot的快速集成多數(shù)據(jù)源的啟動器。
1.首先在pom文件引入dynamic-datasource-spring-boot-starter
<dependency> <groupId>com.baomidou</groupId> <artifactId>dynamic-datasource-spring-boot-starter</artifactId> <version>3.3.2</version> </dependency>
2.application.yml配置文件內(nèi)容如下:
spring: datasource: dynamic: primary: master #設(shè)置默認(rèn)的數(shù)據(jù)源,默認(rèn)值為master strict: false #是否棄用嚴(yán)格模式,如果啟用在味匹配到指定數(shù)據(jù)源時拋出異常 datasource: master: url: jdbc:mysql://192.168.1.110:3306/dynamic1 username: root password: hhl@MySQL_1121 driverClassName: com.mysql.cj.jdbc.Driver test: url: jdbc:mysql://192.168.1.110:3306/dynamic2 username: root password: hhl@MySQL_1121 driverClassName: com.mysql.cj.jdbc.Driver mybatis-plus: configuration: log-impl: org.apache.ibatis.logging.stdout.StdOutImpl server: port: 8080 servlet: context-path: /demo
上面的配置中從dynamic開始是有關(guān)多數(shù)據(jù)源的配置,primary用來配置主數(shù)據(jù)源也叫默認(rèn)數(shù)據(jù)源,它的默認(rèn)值是master,因此,如果不指定primary的話一定要有名為master的數(shù)據(jù)源。strict 是用來配置是否啟用嚴(yán)格 模式,如果為true表示啟用,此時如果沒有匹配的數(shù)據(jù)源會拋出異常,如果為false則會使用默認(rèn)數(shù)據(jù)源。datasource下面就是配置多數(shù)據(jù)源的信息了。
后面的mybatis-plus配置我主要是用來說明集成這個不會對mybatis-plus對配置產(chǎn)生影響,該怎么用mybatis-plus就繼續(xù)怎么用。
3.使用@DS("要切換的數(shù)據(jù)源"),上面配置的test可以使用@DS("test")切換數(shù)據(jù)源
1.注解添加在dao.mapper上無效
2.注解添加到interface Service類上無效
3.注解添加到interface Service方法上無效
那么,此注解應(yīng)該如何使用呢?
添加@DS注解到實現(xiàn)類或者實現(xiàn)類的方法上才可以
當(dāng)注解添加到類上,意味著此類里的方法都使用此數(shù)據(jù)源;
當(dāng)注解添加到方法上時,意味著此方法上使用的數(shù)據(jù)源優(yōu)先級高于其他一切配置
常見問題:
1.不能使用事務(wù),否則數(shù)據(jù)源不會切換,使用的還是是第一次加載的數(shù)據(jù)源 。
刪除 操作多數(shù)據(jù)源的方法或者類、接口 上的 注解 @Transactional() 即可。
2.第一次加載的數(shù)據(jù)源之后,第二次(第三次...)操作其它數(shù)據(jù)源,如果數(shù)據(jù)源不存在,使用的還是第一次加載的數(shù)據(jù)源
3.數(shù)據(jù)源名稱最好不要包含下滑線,下滑線的數(shù)據(jù)源切換不了
拓展-傳播機制
傳播機制生效條件
spring是使用aop來代理事務(wù)控制, 是針對于接口或類的, 所以在同一個 service 類中兩個方法的調(diào)用, 傳播機制是不生效的.
傳播機制常用類型
REQUIRED
支持當(dāng)前事務(wù), 如果當(dāng)前沒有事務(wù),則新建事務(wù)
如果當(dāng)前存在事務(wù), 則加入當(dāng)前事務(wù), 合并成一個事務(wù)
REQUIRES_NEW
新建事務(wù), 如果當(dāng)前存在事務(wù), 則把當(dāng)前事務(wù)掛起
這個方法會獨立提交事務(wù), 不受調(diào)用者的事務(wù)影響, 父級異常, 它也是正常提交
到此這篇關(guān)于MyBatis-Plus 集成動態(tài)多數(shù)據(jù)源的實現(xiàn)示例的文章就介紹到這了,更多相關(guān)MyBatis-Plus 集成動態(tài)多數(shù)據(jù)源內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- MyBatisPuls多數(shù)據(jù)源操作數(shù)據(jù)源偶爾報錯問題
- Mybatis-plus配置多數(shù)據(jù)源,連接多數(shù)據(jù)庫方式
- MyBatis-Plus多數(shù)據(jù)源的示例代碼
- SpringBoot集成Mybatis實現(xiàn)對多數(shù)據(jù)源訪問原理
- Seata集成Mybatis-Plus解決多數(shù)據(jù)源事務(wù)問題
- 詳解SpringBoot Mybatis如何對接多數(shù)據(jù)源
- Mybatis操作多數(shù)據(jù)源的實現(xiàn)
- 一文搞懂MyBatis多數(shù)據(jù)源Starter實現(xiàn)
- Mybatis-plus多數(shù)據(jù)源配置的兩種方式總結(jié)
- Mybatis-Plus的多數(shù)據(jù)源你了解嗎
- mybatis-flex實現(xiàn)多數(shù)據(jù)源操作
相關(guān)文章
Java構(gòu)造器與傳值學(xué)習(xí)總結(jié)
這篇文章主要為大家詳細(xì)介紹了Java構(gòu)造器與傳值學(xué)習(xí)總結(jié),文中示例介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01基于Java?利用Mybatis實現(xiàn)oracle批量插入及分頁查詢
這篇文章主要介紹了基于Java?利用Mybatis實現(xiàn)oracle批量插入及分頁查詢,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,需要的小伙伴可以參考一下2022-07-07SpringBoot配置默認(rèn)HikariCP數(shù)據(jù)源
咱們開發(fā)項目的過程中用到很多的開源數(shù)據(jù)庫鏈接池,比如druid、c3p0、BoneCP等等,本文主要介紹了SpringBoot配置默認(rèn)HikariCP數(shù)據(jù)源,具有一定的參考價值,感興趣的可以了解一下2023-11-11Java并發(fā)編程之CountDownLatch源碼解析
這篇文章主要介紹了Java并發(fā)編程之CountDownLatch源碼解析,文中有非常詳細(xì)的代碼示例,對正在學(xué)習(xí)java并發(fā)編程的小伙伴們有很好的幫助,需要的朋友可以參考下2021-04-04