創新互聯www.cdcxhl.cn八線動態BGP香港云服務器提供商,新人活動買多久送多久,劃算不套路!

springboot 基于mybatis如何實現配置多數據源?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
在實際開發中,我們一個項目可能會用到多個數據庫,通常一個數據庫對應一個數據源。
代碼結構:

簡要原理:
1)DatabaseType列出所有的數據源的key---key
2)DatabaseContextHolder是一個線程安全的DatabaseType容器,并提供了向其中設置和獲取DatabaseType的方法
3)DynamicDataSource繼承AbstractRoutingDataSource并重寫其中的方法determineCurrentLookupKey(),在該方法中使用DatabaseContextHolder獲取當前線程的DatabaseType
4)MyBatisConfig中生成2個數據源DataSource的bean---value
5)MyBatisConfig中將1)和4)組成的key-value對寫入到DynamicDataSource動態數據源的targetDataSources屬性(當然,同時也會設置2個數據源其中的一個為DynamicDataSource的defaultTargetDataSource屬性中)
6)將DynamicDataSource作為primary數據源注入到SqlSessionFactory的dataSource屬性中去,并且該dataSource作為transactionManager的入參來構造DataSourceTransactionManager
7)使用的時候,在dao層或service層先使用DatabaseContextHolder設置將要使用的數據源key,然后再調用mapper層進行相應的操作,建議放在dao層去做(當然也可以使用spring aop+自定注解去做)
注意:在mapper層進行操作的時候,會先調用determineCurrentLookupKey()方法獲取一個數據源(獲取數據源:先根據設置去targetDataSources中去找,若沒有,則選擇defaultTargetDataSource),之后在進行數據庫操作。
1、假設有兩個數據庫,配置如下
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
網頁題目:springboot基于mybatis如何實現配置多數據源-創新互聯
網頁鏈接:http://www.js-pz168.com/article14/gdgge.html
成都網站建設公司_創新互聯,為您提供App開發、網站設計、微信公眾號、面包屑導航、品牌網站制作、網站導航
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯