网站首页
JSP空间
动态资讯
开源项目
技术文档
资源下载
J2EE资源
客户论坛
在线支付
 
  技术文档>>JAVA>>新手入门>>基础入门>查看文档  
  hibernate访问多个数据库     
  文章作者:未知  文章来源:水木森林  
  查看:53次  录入:管理员--2007-11-17  
 
一、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-si、softbrain 担任java开发工作。
博客:http://blog.sina.com.cn/u/1237288325
 
 
上一篇: 在modaldialog中操作父窗口对象    下一篇: 虚拟代理模式(virtual proxy)(图)
  相关文档
jgraph开发经验谈 11-16
thinking in java第三版读书笔记-第九章:异常带来处理错误 11-17
利用 jsp 代码管理您的图像 11-17
j2se综合——关于private构造函数 11-17
java fun and games: java grab包的技术提示 11-17
java 是传值还是传引用 11-17
web 服务代理组件创建 jsf web 服务客户端(1) 11-17
corba 是什么 11-17
如何用servlet打开非html格式的文档 11-17
jre与jdk在启动应用服务器中的作用 11-17
基于mvc的struts在财务系统中的应用 11-16
eclipse中的iadaptable分析 11-17
布尔型 11-17
java异常学习心得 11-17
java截获标准输出 11-17
使用 easy struts for eclipse 开发 struts 11-17
java中异常机制的研究 11-17
充分利用j2ee enterprise blueprint 11-17
java访问在接口中定义的常量 11-17
java使用ant来编译 11-16
返回首页 | 关于我们 | J网章程 | JSP空间合租 | 客服中心 | 免责声明 | 常见问题 | 参观机房
本站主机空间代理至厦门市华众网络科技有限公司
《中华人民共和国增值电信业务经营许可证》
编号:闽B2-20050079
@2005-2008福建JSP技术网 版权所有 闽ICP备05000928号
厦门(总部):13616026886 福州:0591-87655121
邮箱:admin@fjjsp.com 站长QQ,点击这里给我发消息