欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis實現(xiàn)分包定義數(shù)據(jù)庫的原理與過程

 更新時間:2022年01月10日 11:28:35   作者:一懶眾衫小QAQ  
這篇文章主要給大家介紹了關(guān)于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)文章

  • LinkedHashMap如何保證有序問題

    LinkedHashMap如何保證有序問題

    這篇文章主要介紹了LinkedHashMap如何保證有序問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • 使用JAVA實現(xiàn)http通信詳解

    使用JAVA實現(xiàn)http通信詳解

    本文給大家匯總介紹了幾種java實現(xiàn)http通訊的方法,非常的簡單實用,有需要的小伙伴可以參考下。
    2015-08-08
  • 如何更好的使用Java8中方法引用詳解

    如何更好的使用Java8中方法引用詳解

    在Java8中,我們可以直接通過方法引用來簡寫lambda表達式中已經(jīng)存在的方法,這種特性就叫做方法引用(Method Reference)。下面這篇文章主要給大家介紹了關(guān)于如何更好的使用Java8中方法引用的相關(guān)資料,需要的朋友可以參考下。
    2017-09-09
  • @Accessors(chain = true)注解報錯的解決方案

    @Accessors(chain = true)注解報錯的解決方案

    這篇文章主要介紹了@Accessors(chain = true)注解報錯的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • 史上最簡單的MyBatis動態(tài)SQL入門示例代碼

    史上最簡單的MyBatis動態(tài)SQL入門示例代碼

    動態(tài)sql,可以根據(jù)用戶對字段選擇和輸入,動態(tài)生成一條sql執(zhí)行。接下來通過本文給大家分享MyBatis動態(tài)SQL入門示例代碼,一起看看吧
    2017-03-03
  • 必知必會的SpringBoot實現(xiàn)熱部署兩種方式

    必知必會的SpringBoot實現(xiàn)熱部署兩種方式

    這篇文章主要為大家介紹了必知必會的SpringBoot實現(xiàn)熱部署兩種方式詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04
  • java計算兩個日期之間相差天數(shù)的4種方法詳解

    java計算兩個日期之間相差天數(shù)的4種方法詳解

    這篇文章主要給大家介紹了關(guān)于java計算兩個日期之間相差天數(shù)的4種方法,本文簡短地介紹java中多種方式求兩個日期的差量,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-09-09
  • Sentinel中實現(xiàn)限流的兩種方法

    Sentinel中實現(xiàn)限流的兩種方法

    本文給大家介紹了Sentinel中實現(xiàn)限流的兩種方法,限流是一種通過控制系統(tǒng)對外提供的資源、服務(wù)或接口的訪問數(shù)量或速率,以保護系統(tǒng)免受過載的一種策略,需要的朋友可以參考下
    2024-02-02
  • SpringBoot訪問外部文件及默認路由問題

    SpringBoot訪問外部文件及默認路由問題

    這篇文章主要介紹了SpringBoot訪問外部文件及默認路由問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • Java利用Request請求如何獲取IP地址對應(yīng)的省份、城市詳解

    Java利用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

最新評論