一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|編程技術(shù)|正則表達(dá)式|

服務(wù)器之家 - 編程語言 - JAVA教程 - Spring MVC Mybatis多數(shù)據(jù)源的使用實(shí)例解析

Spring MVC Mybatis多數(shù)據(jù)源的使用實(shí)例解析

2020-07-09 10:41java教程網(wǎng) JAVA教程

項(xiàng)目需要從其他網(wǎng)站獲取數(shù)據(jù),因?yàn)槭桥R時(shí)加的需求,這篇文章主要介紹了Spring MVC Mybatis多數(shù)據(jù)源的使用實(shí)例解析,需要的朋友可以參考下

項(xiàng)目需要從其他網(wǎng)站獲取數(shù)據(jù),因?yàn)槭桥R時(shí)加的需求,在開始項(xiàng)目時(shí)沒想到需要多數(shù)據(jù)源

于是百度了一下,發(fā)現(xiàn)只需要改動(dòng)一下Spring 的applicationContext.xml文件和編寫三個(gè)工具類就可以完美實(shí)現(xiàn)

applicationContext.xml

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
<!-- 多數(shù)據(jù)源配置 -->
 <bean id="ds1" class="org.apache.commons.dbcp.BasicDataSource">
  <property name="driverClassName" value="${jdbc.driverClassName}" />
  <property name="url" value="${jdbc.url}" />
  <property name="username" value="${jdbc.username}" />
  <property name="password" value="" />
 </bean>
 <bean id="ds2" class="org.apache.commons.dbcp.BasicDataSource">
  <property name="driverClassName" value="" />
  <property name="url" value="" />
  <property name="username" value="" />
  <property name="password" value="" />
 </bean>
 <!-- 動(dòng)態(tài)配置數(shù)據(jù)源 -->
 <bean id="dataSource" class="com.test.utils.DynamicDataSource">//這里是你項(xiàng)目里DynamicDataSource.java的路徑
  <property name="targetDataSources">
   <map key-type="java.lang.String">
    <entry value-ref="ds_admin" key="ds1"></entry>
    <entry value-ref="ds_partner" key="ds2"></entry>
   </map>
  </property>
  <!-- 默認(rèn)使用ds1的數(shù)據(jù)源 -->
  <property name="defaultTargetDataSource" ref="ds_admin"></property> 
 </bean>

DataSourceContextHolder.java

?
1
2
3
4
5
6
7
8
9
10
11
12
public class DataSourceContextHolder {
 private static final ThreadLocal<String> contextHolder = new ThreadLocal<String>();
 public static void setDbType(String dbType) {
  contextHolder.set(dbType);
 }
 public static String getDbType() {
  return ((String) contextHolder.get());
 }
 public static void clearDbType() {
  contextHolder.remove();
 }
}

DataSourceType.java(設(shè)置靜態(tài)變量)

?
1
2
3
4
5
6
public class DataSourceType {
 // 默認(rèn)數(shù)據(jù)庫
 public static final String SOURCE_ADMIN = "ds1";
 // 第二個(gè)數(shù)據(jù)庫,在applicationContext.xml里的id
 public static final String SOURCE_PARTNER = "ds2";
}

接下來這個(gè)是關(guān)鍵DynamicDataSource.java 它繼承了AbstractRoutingDataSource中的抽象方法determineCurrentLookupKey是實(shí)現(xiàn)數(shù)據(jù)源的route的核心.這里對該方法進(jìn)行Override。

?
1
2
3
4
5
6
7
import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;
public class DynamicDataSource extends AbstractRoutingDataSource {
 @Override
 protected Object determineCurrentLookupKey() {
  return DataSourceContextHolder.getDbType();
 }
}

以上所述是小編給大家介紹的Spring MVC Mybatis多數(shù)據(jù)源的使用實(shí)例解析,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對服務(wù)器之家網(wǎng)站的支持!

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲黄色高清 | 成年男女免费视频观看性 | 青青草国产精品免费 | 国产精品露脸国语对白99 | 色偷偷91久久综合噜噜噜 | 日韩大片在线播放 | 久久视频这里只精品99热在线观看 | 久久国产免费 | 欧美日本一道高清二区三区 | 91大神在线精品视频一区 | 青青网站| 手机在线观看伦理片 | 久久偷拍国2017 | 非洲黑人又大粗gay 非洲黑人bbwbbwbbw | 日本96在线精品视频免费观看 | ai换脸明星造梦工厂忘忧草 | 美女扒开腿让男生桶爽漫画 | 小草视频免费观看在线 | 国产亚洲精品高清在线 | 国产成人精品实拍在线 | 香蕉免费高清完整 | 国产精品免费久久久久影院 | 亚洲国产在线99视频 | 国产在线精品一区二区高清不卡 | 国产一区二区视频免费 | 亚洲国产精品一区二区首页 | www.精品在线 | 欧美一级艳片视频免费观看 | 亚洲 欧美 国产 日韩 字幕 | 婷婷色伊人| 青草久久精品亚洲综合专区 | 亚洲狠狠综合久久 | 91视频国产在线 | 欧美男女交配 | 四虎影视国产精品婷婷 | 美女沟厕撒尿全过程高清图片 | 精品美女国产互换人妻 | 禁欲天堂| 国产精品一级视频 | 日韩欧美在线观看综合网另类 | 天天操免费视频 |