亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2022年01月10日 11:28:35   作者:一懶眾衫小QAQ  
這篇文章主要給大家介紹了關(guān)于Mybatis實(shí)現(xiàn)分包定義數(shù)據(jù)庫的原理與過程,文中通過實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

前言

業(yè)務(wù)需求中需要連接兩個(gè)數(shù)據(jù)庫處理數(shù)據(jù),需要用動(dòng)態(tài)數(shù)據(jù)源。通過了解mybatis的框架,計(jì)劃 使用分包的方式進(jìn)行數(shù)據(jù)源的區(qū)分。

原理

前提:

我們使用mybatis都會(huì)有四個(gè)步驟

1:構(gòu)建SqlSessionFactory

2:通過SqlSessionFactory 獲取到sqlSession 對(duì)象

3:通過sqlSession對(duì)象獲取Mapper的動(dòng)態(tài)代理對(duì)象

4:通過執(zhí)行動(dòng)態(tài)代理對(duì)象獲取返回值

其實(shí)點(diǎn)開sqlSessionFactory就的Configuration對(duì)象中的Environment對(duì)象綁定了我們的dataSource對(duì)象

同樣,我們通過debug發(fā)現(xiàn),動(dòng)態(tài)代理后的mapper對(duì)象是同樣持有Configuration對(duì)象,綁定我們的連接信息。

猜想

需要分包實(shí)現(xiàn)不同數(shù)據(jù)源的話,需要對(duì)不同的mapper指定不同的sqlSessionFactroy,查看mapperScan的注解源碼,

通過理解注釋,我們是可以指定maper動(dòng)態(tài)代理對(duì)象的sqlSessionFactory對(duì)象的。然后結(jié)果basePackages就可以對(duì)不同的包使用不同的sqlSessionFactory從而實(shí)現(xiàn)不同包使用不同的數(shù)據(jù)源。

實(shí)現(xiàn)

1:定義兩個(gè)數(shù)據(jù)源

兩個(gè)數(shù)據(jù)源分別命名位ds01,ds02,這里采用都是德魯伊的數(shù)據(jù)庫連接池。為了簡介,詳細(xì)配置沒有展示了。

2:定義兩個(gè)SqlSessionFactory

定義兩個(gè)sqlSessionFactory,分別綁定兩個(gè)數(shù)據(jù)源。

3:不同包實(shí)現(xiàn)綁定不同的sqlSessionFactory

通過@MapperScan指定掃描的包,通知指定SqlSessionFactory

@MapperScan(basePackages = "com.lenven.demo.dao.ds02",sqlSessionFactoryRef = "salveSqlSessionFactory")
@MapperScan(basePackages = "com.lenven.demo.dao.ds01",sqlSessionFactoryRef = "masterSqlSessionFactory")

4:測試

對(duì)兩個(gè)不同的包的mapper測試,都可以正確查詢出數(shù)據(jù)

拓展:

通過實(shí)現(xiàn)

AbstractRoutingDataSource也可以實(shí)現(xiàn)動(dòng)態(tài)數(shù)據(jù)源。

該類實(shí)現(xiàn)DataSource的接口,可以配置對(duì)各數(shù)據(jù)源在

 @Nullable
    private Map<Object, DataSource> resolvedDataSources;

這個(gè)屬性里面。

讓后通過暴露一個(gè)determineCurrentLookupKey 獲取需要使用的數(shù)據(jù)源的key。但是需要注意事務(wù)的問題。

總結(jié)

到此這篇關(guān)于Mybatis實(shí)現(xiàn)分包定義數(shù)據(jù)庫的原理與過程的文章就介紹到這了,更多相關(guān)Mybatis分包定義數(shù)據(jù)庫內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • LinkedHashMap如何保證有序問題

    LinkedHashMap如何保證有序問題

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

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

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

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

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

    @Accessors(chain = true)注解報(bào)錯(cuò)的解決方案

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

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

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

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

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

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

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

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

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

    SpringBoot訪問外部文件及默認(rèn)路由問題

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

    Java利用Request請(qǐng)求如何獲取IP地址對(duì)應(yīng)的省份、城市詳解

    之前已經(jīng)給大家介紹了關(guān)于Java用Request請(qǐng)求獲取IP地址的相關(guān)內(nèi)容,那么下面這篇文章將給大家進(jìn)入深入的介紹,關(guān)于Java利用Request請(qǐng)求如何獲取IP地址對(duì)應(yīng)省份、城市的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-10-10

最新評(píng)論