spring多數(shù)據(jù)源配置實現(xiàn)方法實例分析
本文實例講述了spring多數(shù)據(jù)源配置實現(xiàn)方法。分享給大家供大家參考,具體如下:
在網(wǎng)上找到的配置多數(shù)據(jù)源的方法。
1.擴展 org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource類
實現(xiàn)代碼
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.實現(xiàn)一個線程安全的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的配置文件。
<!--動態(tài)選擇數(shù)據(jù)源-->
<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>
<!-- 數(shù)據(jù)源定義 -->
<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.切換數(shù)據(jù)源方法。
在serverice方法之前調(diào)用
DbContextHolder.setDbType("2");表示使用第二個數(shù)據(jù)源。
更多關(guān)于java相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Spring框架入門與進階教程》、《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》
希望本文所述對大家java程序設計有所幫助。
- 詳解Spring Boot整合Mybatis實現(xiàn) Druid多數(shù)據(jù)源配置
- 深入理解spring多數(shù)據(jù)源配置
- spring+Jpa多數(shù)據(jù)源配置的方法示例
- 詳解基于Spring Boot與Spring Data JPA的多數(shù)據(jù)源配置
- Spring+MyBatis多數(shù)據(jù)源配置實現(xiàn)示例
- springboot-mongodb的多數(shù)據(jù)源配置的方法步驟
- springboot v2.0.3版本多數(shù)據(jù)源配置方法
- Spring動態(tài)多數(shù)據(jù)源配置實例Demo
- Spring Boot+Jpa多數(shù)據(jù)源配置的完整步驟
- spring基于通用Dao的多數(shù)據(jù)源配置詳解
- Servlet+MyBatis項目轉(zhuǎn)Spring Cloud微服務,多數(shù)據(jù)源配置修改建議
- Spring Boot 2.0多數(shù)據(jù)源配置方法實例詳解
相關(guān)文章
Java中構(gòu)造函數(shù),set/get方法和toString方法使用及注意說明
這篇文章主要介紹了Java中構(gòu)造函數(shù),set/get方法和toString方法的使用及注意說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01
JPA @Query時,無法使用limit函數(shù)的問題及解決
這篇文章主要介紹了JPA @Query時,無法使用limit函數(shù)的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03

