在项目中到一些问题,一些查询模块需要链接另一个数据库,这时,就可以配置两个数据源进行操作。
1.创建jdbc.properties
jdbc.url = jdbc:mysql://localhost:3306/test1?useUnicode=true&characterEncoding=utf8
jdbc.driver = com.mysql.jdbc.Driver
jdbc.username= root
jdbc.password= 123
##第二个数据链接
jdbc.url2 = jdbc:mysql://192.168.1.57:3306/test?useUnicode=true&characterEncoding=utf8
jdbc.driver2 = com.mysql.jdbc.Driver
jdbc.username2 = root
jdbc.password2 = 123
2.获取当前使用的数据源
import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;
/**
* <p>desc:配置多个数据源 </p>
* <p>类名:DynamicDataSource </p>
* <p>创建时间:2018-7-10 上午9:38:42 </p>
* <p>@author:mmy</p>
*/
public class DynamicDataSource extends AbstractRoutingDataSource {
protected Object determineCurrentLookupKey() {
return DBContextHolder.getDbType();
}
}
3.切换数据源的工具类:
/**
* <p>desc: 数据源的切换</p>
* <p>类名:DBContextHolder </p>
* <p>创建时间:2018-7-10 上午9:39:24 </p>
* <p>@author:mmy</p>
*/
public class DBContextHolder {
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.

最低0.47元/天 解锁文章
1256

被折叠的 条评论
为什么被折叠?



