Mybatis實現(xiàn)分包定義數(shù)據(jù)庫的原理與過程
前言
業(yè)務(wù)需求中需要連接兩個數(shù)據(jù)庫處理數(shù)據(jù),需要用動態(tài)數(shù)據(jù)源。通過了解mybatis的框架,計劃 使用分包的方式進行數(shù)據(jù)源的區(qū)分。
原理
前提:
我們使用mybatis都會有四個步驟
1:構(gòu)建SqlSessionFactory
2:通過SqlSessionFactory 獲取到sqlSession 對象
3:通過sqlSession對象獲取Mapper的動態(tài)代理對象
4:通過執(zhí)行動態(tài)代理對象獲取返回值
其實點開sqlSessionFactory就的Configuration對象中的Environment對象綁定了我們的dataSource對象
同樣,我們通過debug發(fā)現(xiàn),動態(tài)代理后的mapper對象是同樣持有Configuration
對象,綁定我們的連接信息。
猜想
需要分包實現(xiàn)不同數(shù)據(jù)源的話,需要對不同的mapper指定不同的sqlSessionFactroy,查看mapperScan的注解源碼,
通過理解注釋,我們是可以指定maper動態(tài)代理對象的sqlSessionFactory對象的。然后結(jié)果basePackages就可以對不同的包使用不同的sqlSessionFactory從而實現(xiàn)不同包使用不同的數(shù)據(jù)源。
實現(xiàn)
1:定義兩個數(shù)據(jù)源
兩個數(shù)據(jù)源分別命名位ds01,ds02,這里采用都是德魯伊的數(shù)據(jù)庫連接池。為了簡介,詳細配置沒有展示了。
2:定義兩個SqlSessionFactory
定義兩個sqlSessionFactory,分別綁定兩個數(shù)據(jù)源。
3:不同包實現(xiàn)綁定不同的sqlSessionFactory
通過@MapperScan指定掃描的包,通知指定SqlSessionFactory
@MapperScan(basePackages = "com.lenven.demo.dao.ds02",sqlSessionFactoryRef = "salveSqlSessionFactory") @MapperScan(basePackages = "com.lenven.demo.dao.ds01",sqlSessionFactoryRef = "masterSqlSessionFactory")
4:測試
對兩個不同的包的mapper測試,都可以正確查詢出數(shù)據(jù)
拓展:
通過實現(xiàn)
AbstractRoutingDataSource也可以實現(xiàn)動態(tài)數(shù)據(jù)源。
該類實現(xiàn)DataSource的接口,可以配置對各數(shù)據(jù)源在
@Nullable private Map<Object, DataSource> resolvedDataSources;
這個屬性里面。
讓后通過暴露一個determineCurrentLookupKey 獲取需要使用的數(shù)據(jù)源的key。但是需要注意事務(wù)的問題。
總結(jié)
到此這篇關(guān)于Mybatis實現(xiàn)分包定義數(shù)據(jù)庫的原理與過程的文章就介紹到這了,更多相關(guān)Mybatis分包定義數(shù)據(jù)庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
@Accessors(chain = true)注解報錯的解決方案
這篇文章主要介紹了@Accessors(chain = true)注解報錯的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06必知必會的SpringBoot實現(xiàn)熱部署兩種方式
這篇文章主要為大家介紹了必知必會的SpringBoot實現(xiàn)熱部署兩種方式詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-04-04Java利用Request請求如何獲取IP地址對應(yīng)的省份、城市詳解
之前已經(jīng)給大家介紹了關(guān)于Java用Request請求獲取IP地址的相關(guān)內(nèi)容,那么下面這篇文章將給大家進入深入的介紹,關(guān)于Java利用Request請求如何獲取IP地址對應(yīng)省份、城市的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。2017-10-10