MyBatis-Plus 集成動(dòng)態(tài)多數(shù)據(jù)源的實(shí)現(xiàn)示例
這里使用的是dynamic-datasource-spring-boot-starter ,它是一個(gè)基于springboot的快速集成多數(shù)據(jù)源的啟動(dòng)器。
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ù)源時(shí)拋出異常
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開(kāi)始是有關(guān)多數(shù)據(jù)源的配置,primary用來(lái)配置主數(shù)據(jù)源也叫默認(rèn)數(shù)據(jù)源,它的默認(rèn)值是master,因此,如果不指定primary的話一定要有名為master的數(shù)據(jù)源。strict 是用來(lái)配置是否啟用嚴(yán)格 模式,如果為true表示啟用,此時(shí)如果沒(méi)有匹配的數(shù)據(jù)源會(huì)拋出異常,如果為false則會(huì)使用默認(rèn)數(shù)據(jù)源。datasource下面就是配置多數(shù)據(jù)源的信息了。
后面的mybatis-plus配置我主要是用來(lái)說(shuō)明集成這個(gè)不會(huì)對(duì)mybatis-plus對(duì)配置產(chǎn)生影響,該怎么用mybatis-plus就繼續(xù)怎么用。
3.使用@DS("要切換的數(shù)據(jù)源"),上面配置的test可以使用@DS("test")切換數(shù)據(jù)源
1.注解添加在dao.mapper上無(wú)效
2.注解添加到interface Service類(lèi)上無(wú)效
3.注解添加到interface Service方法上無(wú)效
那么,此注解應(yīng)該如何使用呢?
添加@DS注解到實(shí)現(xiàn)類(lèi)或者實(shí)現(xiàn)類(lèi)的方法上才可以
當(dāng)注解添加到類(lèi)上,意味著此類(lèi)里的方法都使用此數(shù)據(jù)源;
當(dāng)注解添加到方法上時(shí),意味著此方法上使用的數(shù)據(jù)源優(yōu)先級(jí)高于其他一切配置
常見(jiàn)問(wèn)題:
1.不能使用事務(wù),否則數(shù)據(jù)源不會(huì)切換,使用的還是是第一次加載的數(shù)據(jù)源 。
刪除 操作多數(shù)據(jù)源的方法或者類(lèi)、接口 上的 注解 @Transactional() 即可。
2.第一次加載的數(shù)據(jù)源之后,第二次(第三次...)操作其它數(shù)據(jù)源,如果數(shù)據(jù)源不存在,使用的還是第一次加載的數(shù)據(jù)源
3.數(shù)據(jù)源名稱(chēng)最好不要包含下滑線,下滑線的數(shù)據(jù)源切換不了
拓展-傳播機(jī)制
傳播機(jī)制生效條件
spring是使用aop來(lái)代理事務(wù)控制, 是針對(duì)于接口或類(lèi)的, 所以在同一個(gè) service 類(lèi)中兩個(gè)方法的調(diào)用, 傳播機(jī)制是不生效的.
傳播機(jī)制常用類(lèi)型
REQUIRED
支持當(dāng)前事務(wù), 如果當(dāng)前沒(méi)有事務(wù),則新建事務(wù)
如果當(dāng)前存在事務(wù), 則加入當(dāng)前事務(wù), 合并成一個(gè)事務(wù)
REQUIRES_NEW
新建事務(wù), 如果當(dāng)前存在事務(wù), 則把當(dāng)前事務(wù)掛起
這個(gè)方法會(huì)獨(dú)立提交事務(wù), 不受調(diào)用者的事務(wù)影響, 父級(jí)異常, 它也是正常提交
到此這篇關(guān)于MyBatis-Plus 集成動(dòng)態(tài)多數(shù)據(jù)源的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)MyBatis-Plus 集成動(dòng)態(tài)多數(shù)據(jù)源內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- MyBatisPuls多數(shù)據(jù)源操作數(shù)據(jù)源偶爾報(bào)錯(cuò)問(wèn)題
- Mybatis-plus配置多數(shù)據(jù)源,連接多數(shù)據(jù)庫(kù)方式
- MyBatis-Plus多數(shù)據(jù)源的示例代碼
- SpringBoot集成Mybatis實(shí)現(xiàn)對(duì)多數(shù)據(jù)源訪問(wèn)原理
- Seata集成Mybatis-Plus解決多數(shù)據(jù)源事務(wù)問(wèn)題
- 詳解SpringBoot Mybatis如何對(duì)接多數(shù)據(jù)源
- Mybatis操作多數(shù)據(jù)源的實(shí)現(xiàn)
- 一文搞懂MyBatis多數(shù)據(jù)源Starter實(shí)現(xiàn)
- Mybatis-plus多數(shù)據(jù)源配置的兩種方式總結(jié)
- Mybatis-Plus的多數(shù)據(jù)源你了解嗎
- mybatis-flex實(shí)現(xiàn)多數(shù)據(jù)源操作
相關(guān)文章
java創(chuàng)建excel示例(jxl使用方法)
Java Excel是一開(kāi)放源碼項(xiàng)目,通過(guò)它Java開(kāi)發(fā)人員可以讀取Excel文件的內(nèi)容、創(chuàng)建新的Excel文件、更新 已經(jīng)存在的Excel文件。下面是使用方法,包括去掉網(wǎng)格線、字體設(shè)置、單元格設(shè)置、對(duì)齊方式等設(shè)置2014-03-03
Springboot文件上傳功能的實(shí)現(xiàn)
這篇文章主要介紹了SpringBoot文件上傳功能的實(shí)現(xiàn),文中通過(guò)代碼示例介紹的非常詳細(xì),具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們可以參考閱讀2023-04-04
Spring事件監(jiān)聽(tīng)器ApplicationListener源碼詳解
這篇文章主要介紹了Spring事件監(jiān)聽(tīng)器ApplicationListener源碼詳解,ApplicationEvent以及Listener是Spring為我們提供的一個(gè)事件監(jiān)聽(tīng)、訂閱的實(shí)現(xiàn),內(nèi)部實(shí)現(xiàn)原理是觀察者設(shè)計(jì)模式,需要的朋友可以參考下2023-05-05
Spring動(dòng)態(tài)代理實(shí)現(xiàn)日志功能詳解
這篇文章主要為大家詳細(xì)介紹了Spring動(dòng)態(tài)代理實(shí)現(xiàn)日志功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
命令行使用支持?jǐn)帱c(diǎn)續(xù)傳的java多線程下載器
java命令行下載器,支持?jǐn)帱c(diǎn)續(xù)傳下載,多線程下載,需要的朋友可以參考下2014-02-02

