91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

spring多數據源配置實現方法實例分析

發布時間:2020-10-17 15:00:57 來源:腳本之家 閱讀:127 作者:自由港 欄目:編程語言

本文實例講述了spring多數據源配置實現方法。分享給大家供大家參考,具體如下:

在網上找到的配置多數據源的方法。

1.擴展 org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource

實現代碼

import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;
public class DynamicDataSource extends AbstractRoutingDataSource {
  @Override
  protected Object determineCurrentLookupKey() {
    // TODO Auto-generated method stub
    return DbContextHolder.getDbType();
  }
}

2.實現一個線程安全的DbContextHolder類。

public class DbContextHolder {
    private static final ThreadLocal contextHolder = new ThreadLocal();
    public static void setDbType(String dbType)
    {
      contextHolder.set(dbType);
    }
    /**
     * 取得dbtype類型
     * @return
     */
    public static String getDbType()
    {
      String str=(String) contextHolder.get();
      if(null==str || "".equals(str))
        str="1";
      return str;
    }
    public static void clearDbType()
    {
      contextHolder.remove();
    }
}

3.修改spring的配置文件。

<!--動態選擇數據源-->
  <bean id="dataSource" class="tecamo.core.utils.DynamicDataSource">
    <property name="targetDataSources">
      <map key-type="java.lang.String">
        <entry key="1" value-ref="ds1"/>
        <entry key="2" value-ref="ds2"/>
      </map>
    </property>
    <property name="defaultTargetDataSource" ref="ds1"/>
  </bean>
  <!-- 數據源定義 -->
  <bean id="ds1" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
    <property name="driverClassName" value="${jdbc.driverClassName}"/>
    <property name="url" value="${jdbc.url}"/>
    <property name="username" value="${jdbc.username}"/>
    <property name="password" value="${jdbc.password}"/>
  </bean>
  <bean id="ds2" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
    <property name="driverClassName" value="${jdbcOrcale.driverClassName}"/>
    <property name="url" value="${jdbcOrcale.url}"/>
    <property name="username" value="${jdbcOrcale.username}"/>
    <property name="password" value="${jdbcOrcale.password}"/>
  </bean>

4.切換數據源方法。

在serverice方法之前調用

DbContextHolder.setDbType("2");表示使用第二個數據源。

更多關于java相關內容感興趣的讀者可查看本站專題:《Spring框架入門與進階教程》、《Java數據結構與算法教程》、《Java操作DOM節點技巧總結》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》

希望本文所述對大家java程序設計有所幫助。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宾阳县| 思南县| 淮北市| 澄城县| 邵武市| 云林县| 柏乡县| 桑植县| 昭觉县| 西平县| 苏州市| 土默特右旗| 凭祥市| 临安市| 萨嘎县| 顺昌县| 桂阳县| 临夏市| 科技| 梅州市| 和田市| 海门市| 桃源县| 波密县| 腾冲县| 綦江县| 建水县| 琼结县| 叙永县| 柘城县| 鸡东县| 内丘县| 淳化县| 沂水县| 漾濞| 金塔县| 湖南省| 正定县| 台南县| 远安县| 家居|