一、
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
。
本Blog纯属个人学习、工作需要,记录相关资料。请不要发表任何有人身攻击的言论,谢谢! www.zhipsoft.cn
posted on 2007-01-03 10:37
ZhipSoft 阅读(790)
评论(0) 编辑 收藏 所属分类:
Hibernate