现在的位置: 首页 > 综合 > 正文

Hibernate访问多个数据库

2014年01月04日 ⁄ 综合 ⁄ 共 2501字 ⁄ 字号 评论关闭
一、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,多数据库就更简单了,像这段代码可以完成所有配置: 
jdbc:mysql://localhost:3306/test
org.gjt.mm.mysql.Driver  
root  
123
org.hibernate.dialect.MySQLDialect
test.hbm.xml
jdbc:odbc:test
sun.jdbc.odbc.JdbcOdbcDriver
root
123
org.hibernate.dialect.SQLServerDialect
test.hbm.xml.......
以上只是配置Hibernate访问多个数据库的一般方法,hibernate还有很多可行的配置,有兴趣的读者可
以参考它的reference。
关于作者:
杨晓,北京工商大学计算机硕士,曾在NEC-SI、Softbrain 担任java开发工作。
博客:http://blog.sina.com.cn/u/1237288325

抱歉!评论已关闭.