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)文章
SpringBoot整合JWT(JSON?Web?Token)生成token與驗證的流程及示例
JSON Web Token(JWT)是一種開放的標準(RFC 7519),定義了一種緊湊的、自包含的方式來安全地在各方之間傳輸信息作為JSON對象,這篇文章主要給大家介紹了關(guān)于SpringBoot整合JWT(JSON?Web?Token)生成token與驗證的相關(guān)資料,需要的朋友可以參考下2024-07-07
使用java swing實現(xiàn)qq登錄界面示例分享
這篇文章主要介紹了使用java swing實現(xiàn)qq登錄界面示例,需要的朋友可以參考下2014-04-04
Mac使用Idea配置傳統(tǒng)SSM項目(非maven項目)
本文主要介紹了Mac使用Idea配置傳統(tǒng)SSM項目(非maven項目),將展示如何設(shè)置項目結(jié)構(gòu)、添加依賴關(guān)系等,具有一定的參考價值,感興趣的可以了解一下2024-01-01
JSON.toJSONString()方法在Java中的使用方法及應(yīng)用場景
這篇文章主要給大家介紹了關(guān)于JSON.toJSONString()方法在Java中的使用方法及應(yīng)用場景,JSON.toJSONString是將對象轉(zhuǎn)化為Json字符串,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2024-04-04
Java 是如何利用接口避免函數(shù)回調(diào)的方法
本篇文章主要介紹了Java 是如何利用接口避免函數(shù)回調(diào)的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-02-02

