同一个SSM项目配置多个数据库
程序员文章站
2024-03-21 19:54:04
...
有时候项目可能会连接到不同的数据库上获取数据,那么怎么才能*切换,让代码查询想要的数据库呢,步骤如下
1,配置数据库连接信息
##第一个数据库信息
DB_MSSQL_URL_1=jdbc:mysql://127.0.0.1:3358/user_1?allowMultiQueries=true
DB_MSSQL_DRIVER_1=com.mysql.jdbc.Driver
DB_MSSQL_USER_1=root
DB_MSSQL_PW_1=456
##第二个数据库信息
DB_MSSQL_URL_2=jdbc:mysql://127.0.0.1:3358/user_2?allowMultiQueries=true
DB_MSSQL_DRIVER_2=com.mysql.jdbc.Driver
DB_MSSQL_USER_2=root
DB_MSSQL_PW_2=123
2,创建数据库的bean
<!--第一数据库的信息-->
<bean id="dataSource1" destroy-method="close" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName">
<value>${DB_MSSQL_DRIVER_1}</value>
</property>
<property name="url">
<value>${DB_MSSQL_CMS_URL_1}</value>
</property>
<property name="username">
<value>${DB_MSSQL_USER_1}</value>
</property>
<property name="password">
<value>${DB_MSSQL_PW_1}</value>
</property>
</bean>
<!--第二数据库的信息-->
<bean id="dataSource2" destroy-method="close" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName">
<value>${DB_MSSQL_DRIVER_2}</value>
</property>
<property name="url">
<value>${DB_MSSQL_CMS_URL_2}</value>
</property>
<property name="username">
<value>${DB_MSSQL_USER_2}</value>
</property>
<property name="password">
<value>${DB_MSSQL_PW_2}</value>
</property>
</bean>
3,配置数据库连接池
<!-- 编写spring 配置文件的配置多数源映射关系 -->
<bean class="com.lgg.utils.DynamicDataSource" id="dynamicDataSource">
<property name="targetDataSources">
<map key-type="java.lang.String">
<entry value-ref="dataSource1" key="dataSource1"></entry>
<entry value-ref="dataSource2" key="dataSource2"></entry>
</map>
</property>
<property name="defaultTargetDataSource" ref="dataSource1"></property>
</bean>
<!-- 事务管理器 -->
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<!-- 配置为dynamicDataSource -->
<property name="dataSource" ref="dynamicDataSource"/>
</bean>
<tx:annotation-driven transaction-manager="txManager"/>
<!--自动加载所有的mapper.xml文件,不再需要单独配置 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 配置为dynamicDataSource -->
<property name="dataSource" ref="dynamicDataSource"/>
<property name="configLocation" value="classpath:spring/sqlMapConfig.xml"/>
<property name="mapperLocations">
<value>classpath:mybatis/*.xml</value>
</property>
</bean>
4,创建类指定用哪个数据库
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.remove();
}
}
5,自定义动态数据源
public class DynamicDataSource extends AbstractRoutingDataSource {
@Override
protected Object determineCurrentLookupKey() {
return DBContextHolder.getDbType();
}
}
6,在java代码动态确定调用哪个数据库
public void getUserById(Integer id) {
User user ;
if(id == 1){
//调用数据库1
DBContextHolder.setDbType("dataSource1");
user = userDao.getUserById(1);
}else{
//调用数据库2
DBContextHolder.setDbType("dataSource2");
user = userDao.getUserById(2);
}
return user;
}
本人做笔记使用,参考:https://blog.csdn.net/u011900448/article/details/79933149
上一篇: JAVA基础之多态
推荐阅读
-
同一个SSM项目配置多个数据库
-
django rest framework如何一次性序列化同一个数据库下多个model表数据在一个json页面下
-
sae上django项目的数据库配置 博客分类: python djangosae
-
GitHub中多个项目上传到同一个仓库
-
配置ssm项目报错:No qualifying bean of type ... found for dependency ...expected at least 1 bean which
-
Centos 5.2下安装多个mysql数据库配置详解
-
SSM项目中配置LOG4J日志的方法
-
Centos 5.2下安装多个mysql数据库配置详解
-
SSM项目中配置LOG4J日志的方法
-
ssm框架下web项目,web.xml配置文件的作用(详解)