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-SI、Softbrain 担任java开发工作。
博客:http://blog.sina.com.cn/u/1237288325
MSN: South-Titan@hotmail.com
分享到:
相关推荐
总评成 绩数据库课程设计说明书学生成绩管理系统学生姓名: 王浩 学号: 1707004716 学 院: 大数据学院 专 业: 计算机科学与技术 指导教师: 杨晓
工程项目管理杨晓庄编总复习.pdf
2110461106杨晓羽SQLQuery1.sql
陕西多元化养老服务体系建设研究_杨晓.caj
项目主文件,文件内含有两个函数。 预约程序,用来测试是否能够正常预约。运行效果如下。 欢迎使用ddddocr,本项目专注带动行业内卷,个人博客:wenanzhe.com 训练数据支持来源于:...
基于达曼光栅的激光雷达线阵照明研究_杨晓旦.caj
1、数据来源:国泰安数据库 2、时间跨度:1998-2019 3、区域范围:各上市公司 4、指标说明: 此次皮皮侠分享数据主要构建了mangerpower、power这两个指标。这两大指标都是参考以下A类核心期刊(如经济研究、会计研究...
2. 借鉴Fan等(2009)、卢锐等(2008) 对管理层权力的间接度量方法,按照主成分分析方法将五个指标合成管理层权力综合指标; 3. pca因子分析; 4. KMO和SMC检验 数据范围: 1999-2018年;所有原始数据来自CSMAR数据库
matlab、maxdea多次重复测度拟合的最优结果,还希望大家多多支持。 投入 指标:劳动力投入、固定资产投资、能源消耗 产出指标:实际GDP(期望) 废水、S O2与烟尘(非期望) 模型设定:超效率SBM模型,产出导向 此外...
审计常用定性表述及适用法规向导(DOC154页).doc
【《谈传世》阅读答案】名医传世培训试题答案.docx
[2] 杨晓,MIMO 多天线无线通信系统,邮电出版社,北京,2009。 您可以通过调整参数 b 来获得不同大小的 Tanner 代码,该参数应为质数 [1,2]。 现有的 Tanner 码无法导出准圆形生成矩阵,我们修改了 Tanner 码的...
模拟 2*2 MIMO-LDPC 基带系统版权所有(C2010-2015... [1] 杨晓,MIMO多天线无线通信系统,邮电出版社,北京,2009。 与 IEEE 802.16e 的 MIMO 方案不同,我们的 MIMO-LDPC 系统没有空时编码,但实现了良好的 BER 性能。
我国山地拖拉机车身调平系统研究进展,杨晓,毛恩荣,我国耕地多处于丘陵山地之中,山地拖拉机车身调平技术是减轻劳动强度和提高生产率的关键技术,在他领域也有广泛的应用前景。对目
这是我在清软学习时 杨晓裴老师给的关于javascript 的PPT 资料 个人觉得 还挺全的 所以上传上来和大家分享
基于the Grinder的性能测试及应用,杨晓旗,,如何选择适合不同用户需求的性能测试工具并且执行测试,找出系统可能存在的系统瓶颈和系统漏洞,是软件性能测试的关键。本文提出
基本循环化学吸附式制冷建模与分析,冯玉坤,杨晓,在分析基本吸附制冷循环的基础上,建立了吸附制冷热力过程中的计算表达式.采用Matlab/Simulink模拟手段对氯化钙-氨制冷工况对制冷性能�
宁波市沿海旅游资源比较研究,张磊,杨晓仙,宁波市滨海旅游资源具有“滩、岩、岛”三大特色,形成了一定规模的旅游资源,具有较高的旅游开发价值。本文结合宁波市旅游资源普
上海市尚德实验学校杨晓 Email:qdyangxiao@hotmail.com 初一数学竞赛讲座(一) 自然数的有关性质 一、知识要点 1、 最大公约数 定义 1 如果 a1,a2,…,an和
基于微流控技术可控制备响应型光子晶体微珠,杨晓煜,张静,基于微流控技术,在微通道受限空间中实现材料的有序组装与功能复合,是目前构筑各类功能性杂化材料的有效方式。本文借助微流控技