spring+hibernate多数据源的应用

3 篇文章 0 订阅
2 篇文章 0 订阅
我有两个数据库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 extendsAbstractRoutingDataSourc e{
      @Override
      protectedObject determineCurrentLookupKe y() {
            // TODOAuto-generated method stub
              return DBContextHolder.getDB();
      }

}


//编写测试类
public class Test {
      publicstatic void main(String[] args) {
            ApplicationContext context=newClassPathXmlApplicationC ontext("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();
      }
}


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值