spring+hibernate多数据源的应用

本文介绍了一种在Spring框架下实现多个数据库之间的动态切换的方法。通过配置不同的数据源,并使用自定义的数据源管理类,可以在运行时根据业务需求选择合适的数据源进行操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我有两个数据库test,和test1,两个库里都有一张表TEST_ONE
applicationContext.xml的配置如下

//数据库test配置
<bean id="test"
 
     class="org.springframework.jdbc.datasource.DriverManagerDataSource">
      <property name="driverClassName"value="com.mysql.jdbc.Driver">
      </property>
      <property name="url"value="jdbc:mysql://localhost:3306/test"></property>
      <property name="username"value="root"></property>
      <property name="password"value="root"></property>
   </bean>
   
//数据库test1配置
   <beanid="test1"
      class="org.springframework.jdbc.datasource.DriverManagerDataSource">
      <property name="driverClassName"value="com.mysql.jdbc.Driver">
      </property>
      <property name="url"value="jdbc:mysql://localhost:3306/test1"></property>
      <property name="username"value="root"></property>
      <property name="password"value="root"></property>
      
   </bean>
  //整合两个数据源,指定数据源管理类
   <beanid="dataSource"class="com.keith.dataSource.DynamicDataSource">
      <propertyname="targetDataSources">
         <mapkey-type="java.lang.String">
            <entry key="test" value-ref="test"/>
            <entry key="test1" value-ref="test1"/>
         </map>
      </property>
//设置默认数据源配置
      <property name="defaultTargetDataSource" ref="test"/>
      
   </bean>
 <bean id="sessionFactory"
      class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
      <property name="dataSource">
         <ref bean="dataSource" />
      </property>
      <propertyname="hibernateProperties">
         <props>
            <prop key="hibernate.dialect">
               org.hibernate.dialect.MySQLDialect
            </prop>
         </props>
      </property>
      <propertyname="mappingResources">
      <list>
      <value>com/keith/vo/TestOne.hbm.xml</value></list>
      </property>
   </bean >
 
    
数据源切换的工具类:
public class DBContextHolder {
   //数据库test
   public static final StringDB_TEST="test";
   //数据库test1
   public static final StringDB_TEST_1="test1";
   private static finalThreadLocalCON_LOCAL=new ThreadLocal();
   public static voidsetDB(String type){
      CON_LOCAL.set(type);
   }
   public static StringgetDB(){
      return(String)CON_LOCAL.get();
   }
   public static voidclearDB(){
      CON_LOCAL.remove();
   }
}


//这个类是用来管理数据源的,配置文件中
public class DynamicDataSource extendsAbstractRoutingDataSource{
   @Override
    protectedObject determineCurrentLookupKey() {
       // TODOAuto-generated method stub
       return DBContextHolder.getDB();
    }

}


//编写测试类
public class Test {
    publicstatic void main(String[] args) {
      ApplicationContext context=newClassPathXmlApplicationContext("applicationContext.xml");
      //动态设置数据源
      DBContextHolder.setDB(DBContextHolder.DB_TEST_1);
      SessionFactory sf=(SessionFactory)context.getBean("sessionFactory");
       Session s=sf.openSession();
       Transactiontr=s.getTransaction();
      tr.begin();
       TestOneone=new TestOne();
      one.setName("aaa");
      s.save(one);
      tr.commit();
      sf.close();
    }
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值