專案需要從其他網站取得數據,因為是臨時加的需求,在開始專案時沒想到需要多資料來源
於是百度了一下,發現只需要改動一下Spring 的applicationContext.xml檔案和編寫三個工具類就可以完美實作
applicationContext.xml
<!-- 多数据源配置 --> <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> <!-- 动态配置数据源 --> <bean id="dataSource" class="com.test.utils.DynamicDataSource">//这里是你项目里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> <!-- 默认使用ds1的数据源 --> <property name="defaultTargetDataSource" ref="ds_admin"></property> </bean>
DataSourceContextHolder.java
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.javaHolder.java
public class DataSourceType { // 默认数据库 public static final String SOURCE_ADMIN = "ds1"; // 第二个数据库,在applicationContext.xml里的id public static final String SOURCE_PARTNER = "ds2"; }
stractRoutingDataSource中的抽象方法determineCurrentLookupKey是實作資料來源的route的核心.這裡對此方法進行Override。
import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource; public class DynamicDataSource extends AbstractRoutingDataSource { @Override protected Object determineCurrentLookupKey() { return DataSourceContextHolder.getDbType(); } }
以上所述是小編給大家介紹的Spring MVC Mybatis多資料來源的使用實例解析,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對PHP中文網的支持!
更多Spring MVC Mybatis多重資料來源的使用實例解析相關文章請關注PHP中文網!