Hibernate访问多个数据库

项目需要配置Spring多数据源,在网上找了半天,才发现这篇文章。

http://blog.csdn.net/SouthTitan/archive/2006/06/22/822691.aspx 

Hibernate 访问多个数据库
作者:杨晓
来源:http://blog.sina.com.cn/u/1237288325
 
一、             Hibernate访问数据库时加载的过程
对于大多数使用 Hibernate 的朋友来说,通常使用一下方式来获得 Configuration 实例: Configuration configure = new Configuration().configure();
Hibernate 中, Configuration hibernate 的入口。在实例化一个 Configuration 的时候, Hibernate 会自动在环境变量( classpath )里面查找 Hibernate 配置文件 hibernate.properties 。如果该文件存在,则将该文件的内容加载到一个 Properties 的实例 GLOBAL_PROPERTIES 里面,如果不存在,将打印信息   hibernate.properties not found
接下来 Hibernate 将所有系统环境变量( System.getProperties() )也添加到 GLOBAL_PROPERTIES 里面。如果配置文件 hibernate.properties 存在,系统还会进一步验证这个文件配置的有效性,对于一些已经不支持的配置参数,系统将打印出警告信息。
默认状态下 configure() 方法会自动在环境变量( classpath )下面寻找 Hibernate 配置文件 hibernate.cfg.xml ,如果该文件不存在,系统会打印如下信息并抛出 HibernateException 异常 : hibernate.cfg.xml not found 如果该文件存在, configure() 方法会首先访问< session-factory >,并获取该元素 name 的属性,如果 name 的属性非空,将用这个配置的值来覆盖 hibernate.properties hibernate.session_factory_name 的配置的值,从这里我们可以看出, hibernate.cfg.xml 里面的配置信息可以覆盖 hibernate.properties 的配置信息。
接下来 configure() 方法访问< session-factory >的子元素,首先将使用所有的< property >元素配置的信息来覆盖 hibernate.properties 里面对应的配置信息。
然后 configure() 会依次访问以下几个元素的内容
<mapping
<jcs-class-cache
<jcs-collection-cache
<collection-cache
其中< mapping >是必不可少的,必须通过配置< mapping >, configure() 才能访问到我们定义的 java 对象和关系数据库表的映射文件( hbm.xml ),例如:
<mapping resource="Cat.hbm.xml"/>
这样 configure() 方法利用各种资源就创建了一个 Configuration 实例。对于整个项目来说,如果用一个本地线程来存放这个 Configuration 实例,那么整个项目只需要实例化一次 Configuration 对象(注: Configuration 实例很花费时间),也就提高了项目的效率。
 
二、             Hibernate访问多个数据库的配置
根据以上所述, configure() 方法默认是通过访问 hibernate.cfg.xml 的< mapping >元素来加载我们提供的 .hbm.xml 文件。我们也可以直接指定 hbm.xml 文件,例如 addClass() 方法可以直接通过指定 class 来加载对应的映射文件, hibernate 会将提供的 class 的全名(包括 package )自动转化为文件路径,还可以用 addFile 方法直接指定映射文件。例如: Configuration configurate = new Configuration().addClass(“Book.class”);
Configuration configurate = new Configuration().addURL(Configuration.class.getResource ("/Book.hbm.xml"));
Configuration config = new Configuration().addFile("/Cat.hbm.xml");

这样,如果用 xml 配置来配置多个数据库的话,那就写多个配置文件。这里假设对应两个数据库(一个是 MySQL ,一个是 SQLServer ),我们可以把其 xml 文件定义为“ mysql.cfg.xml ”和“ sqlserver.cfg.xml ”。则用 Configuration 类获取 SessionFactory 的代码如下:
SessionFactory mysqlFactory = new Configuration().configure("/mysql.cfg.xml").buildSessionFactory();
SessionFactory sqlserverFactory = new Configuration().configure("sqlserver.cfg.xml ").buildSessionFactory();
如果你用 spring ,多数据库就更简单了,像这段代码可以完成所有配置:
<beans>
<bean id="mysqlDS" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="url">
<value>jdbc:mysql://localhost:3306/test</value>
</property>
<property name="driverClassName">
<value>org.gjt.mm.mysql.Driver</value>
</property>
<property name="username">
<value>root</value>
</property>
<property name="password">
<value>123</value>
</property>
</bean>

<bean id="mysqlFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref local="mysqlDS"/>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>test.hbm.xml</value>
</list>
</property>
</bean>

<bean id="sqlserverDS" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="url">
<value>jdbc:odbc:test</value>
</property>
<property name="driverClassName">
<value>sun.jdbc.odbc.JdbcOdbcDriver</value>
</property>
<property name="username">
<value>root</value>
</property>
<property name="password">
<value>123</value>
</property>
</bean>

<bean id="sqlserverFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref local="sqlserverDS"/>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>test.hbm.xml</value>
</list>
</property>
</bean>
.......
</beans>

以上只是配置 Hibernate 访问多个数据库的一般方法, hibernate 还有很多可行的配置,有兴趣的读者可以参考它的 reference
关于作者:
杨晓,北京工商大学计算机硕士,曾在NEC-SISoftbrain 担任java开发工作。
博客:http://blog.sina.com.cn/u/1237288325
MSN: South-Titan@hotmail.com
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值