内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

springboot基于mybatis如何實現(xiàn)配置多數(shù)據(jù)源-創(chuàng)新互聯(lián)

創(chuàng)新互聯(lián)www.cdcxhl.cn八線動態(tài)BGP香港云服務器提供商,新人活動買多久送多久,劃算不套路!

成都創(chuàng)新互聯(lián)制作網(wǎng)站網(wǎng)頁找三站合一網(wǎng)站制作公司,專注于網(wǎng)頁設(shè)計,網(wǎng)站設(shè)計、網(wǎng)站制作,網(wǎng)站設(shè)計,企業(yè)網(wǎng)站搭建,網(wǎng)站開發(fā),建網(wǎng)站業(yè)務,680元做網(wǎng)站,已為成百上千家服務,成都創(chuàng)新互聯(lián)網(wǎng)站建設(shè)將一如既往的為我們的客戶提供最優(yōu)質(zhì)的網(wǎng)站建設(shè)、網(wǎng)絡營銷推廣服務!

springboot 基于mybatis如何實現(xiàn)配置多數(shù)據(jù)源?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

在實際開發(fā)中,我們一個項目可能會用到多個數(shù)據(jù)庫,通常一個數(shù)據(jù)庫對應一個數(shù)據(jù)源。

代碼結(jié)構(gòu):

springboot 基于mybatis如何實現(xiàn)配置多數(shù)據(jù)源

簡要原理:

1)DatabaseType列出所有的數(shù)據(jù)源的key---key

2)DatabaseContextHolder是一個線程安全的DatabaseType容器,并提供了向其中設(shè)置和獲取DatabaseType的方法

3)DynamicDataSource繼承AbstractRoutingDataSource并重寫其中的方法determineCurrentLookupKey(),在該方法中使用DatabaseContextHolder獲取當前線程的DatabaseType

4)MyBatisConfig中生成2個數(shù)據(jù)源DataSource的bean---value

5)MyBatisConfig中將1)和4)組成的key-value對寫入到DynamicDataSource動態(tài)數(shù)據(jù)源的targetDataSources屬性(當然,同時也會設(shè)置2個數(shù)據(jù)源其中的一個為DynamicDataSource的defaultTargetDataSource屬性中)

6)將DynamicDataSource作為primary數(shù)據(jù)源注入到SqlSessionFactory的dataSource屬性中去,并且該dataSource作為transactionManager的入?yún)順?gòu)造DataSourceTransactionManager

7)使用的時候,在dao層或service層先使用DatabaseContextHolder設(shè)置將要使用的數(shù)據(jù)源key,然后再調(diào)用mapper層進行相應的操作,建議放在dao層去做(當然也可以使用spring aop+自定注解去做)

注意:在mapper層進行操作的時候,會先調(diào)用determineCurrentLookupKey()方法獲取一個數(shù)據(jù)源(獲取數(shù)據(jù)源:先根據(jù)設(shè)置去targetDataSources中去找,若沒有,則選擇defaultTargetDataSource),之后在進行數(shù)據(jù)庫操作。

 1、假設(shè)有兩個數(shù)據(jù)庫,配置如下

application.properties

#the first datasource
jdbc.driverClassName = com.mysql.jdbc.Driver
jdbc.url = jdbc:mysql://xxx:3306/mytestdb?zeroDateTimeBehavior=convertToNull&useUnicode=true&characterEncoding=utf-8
jdbc.username = root
jdbc.password = 123

#the second datasource
jdbc2.driverClassName = com.mysql.jdbc.Driver
jdbc2.url = jdbc:mysql://xxx:3306/mytestdb2?zeroDateTimeBehavior=convertToNull&useUnicode=true&characterEncoding=utf-8
jdbc2.username = root
jdbc2.password = 123

網(wǎng)頁題目:springboot基于mybatis如何實現(xiàn)配置多數(shù)據(jù)源-創(chuàng)新互聯(lián)
網(wǎng)頁鏈接:http://www.rwnh.cn/article14/gdgge.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App開發(fā)、網(wǎng)站設(shè)計微信公眾號、面包屑導航品牌網(wǎng)站制作、網(wǎng)站導航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設(shè)
石阡县| 禹城市| 文安县| 吴堡县| 平湖市| 丹江口市| 凯里市| 林州市| 白山市| 阿合奇县| 瑞丽市| 栾川县| 阿图什市| 文成县| 肥乡县| 蓝山县| 广宗县| 昆明市| 东兰县| 新营市| 饶河县| 资兴市| 修水县| 滦平县| 息烽县| 琼海市| 宣化县| 呼玛县| 资讯| 龙游县| 二手房| 仁寿县| 太保市| 田东县| 鱼台县| 格尔木市| 廉江市| 仁怀市| 盖州市| 平果县| 子长县|