`

Hibernate访问多个数据库

阅读更多

 一、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。

 

http://itlab.idcquan.com/Java/net/396847.html

连接操作两个数据库:(可以简单看一下)

http://blog.csdn.net/cnboynet/article/details/6935605

分享到:
评论

相关推荐

    JAVA数据库访问控制框架

    这个数据库访问控制框架工程名为dbmanager,目前的版本是1.1.8,只支持MYSQL数据库,在未来的两周时间内我会发布后续扩展版本,加入对SQLSERVER, ORACLE,SYBASE,DB2数据库的支持。 之所以想写这个框架,最主要的一个...

    Hibernate_3.2.0_符合Java习惯的关系数据库持久化

    16.1.4. 返回多个实体(Returning multiple entities) 16.1.5. 返回非受管实体(Returning non-managed entities) 16.1.6. 处理继承(Handling inheritance) 16.1.7. 参数(Parameters) 16.2. 命名SQL查询 ...

    JAVA数据库访问控制框架文档

    这个数据库访问控制框架工程dbmanager的文档,目前的版本是1.5.6,在原版本1.1.8对MYSQL的支持上加入了对SQLSERVER, ORACLE,SYBASE,DB2数据库的支持。 之所以想写这个框架,最主要的一个原因是,目前在JAVA开发中...

    hibernate-reactive:Hibernate ORM的React式API,支持非阻塞数据库驱动程序以及与数据库交互的React式

    Hibernate Reactive来访问数据库, 编写Java代码以数据模型, 编写React式数据访问代码,以及 程序。 我们建议您从这里开始! 范例程序 目录中有一个非常简单的示例程序。 Gradle构建 该项目是建立与Gradle,但...

    hibernate3

    (1)Configuration:用于解析hibernate.cfg.xml文件和XXXXX.hbm.xml文件...如果应用同时访问多个DB,怎需要为每个数据库创建一个单独的SessionFactory实例。 (3)Session:也被称为持久化管理器,对象级数据库操作。

    Android数据库hibernate框架.

    现在每个方法都自己开启和关闭事务,暂时还不支持在一个事务中做多个操作然后统一提交事务. * (三)作者寄语: * 昔日有JavaScript借Java发展,今日也希望AHibernate借Hibernate之名发展. * 希望这个项目...

    Hibernate工作原理及为什么要用

    其中的数据可被多个 Session 共享访问。 三、Hibernate 中 Java 对象的状态 在 Hibernate 中,Java 对象可以处于三种状态: 1. 临时状态(transient):特征是不处于 Session 缓存中,数据库中没有对象记录。Java...

    BeetlSQL数据库访问框架是一个全功能 DAO 工具,同时具有 Hibernate.rar

    BeetSql是一个全功能DAO工具,同时具有Hibernate 优点 & Mybatis优点功能,适用于承认以SQL为中心,同时又需求工具能自动能生成大量常用的SQL的应用。 在开发效率上,无需注解,自动使用大量内置SQL,轻易完成增删...

    JAVA数据库访问控制框架V1.5.6

    这个数据库访问控制框架工程名为dbmanager,目前的版本是1.5.6,已在上一次发布的1.1.8版本的基础上加入了对SQLSERVER, ORACLE,SYBASE,DB2数据库的支持。 之所以想写这个框架,最主要的一个原因是,目前在JAVA开发中...

    新建Hibernate项目web.rar

    1.Hibernate 对 JDBC 访问数据库的代码进行了轻量级封装,大大简化了数据访问层繁琐的重复性代码,并且减少了内存消耗,加快了运行效率。 2.Hibernate 使用 Java 的反射机制,而不是使用字节码增强程序类,并实现了...

    Hibernate搜索框架HibernateSearch.zip

    等通配符号),多关键字,模糊查询,排序等6,支持Clustering7,支持直接访问Lucene API8,对Lucene索引,API的高效管理Hibernate Search运行的环境如下:1、JDK或JRE 5.0以上2、Hibernate-Search以及相应的依赖包3...

    网上书城系统(Struts+Hibernate+Mysql).zip

    Hibernate框架是一个对象关系映射(ORM)框架,它能够将Java对象与数据库表进行映射,实现Java对象与数据库之间的自动转换。在网上书城系统中,Hibernate框架负责处理与MySQL数据库的交互操作,如查询书籍信息、添加...

    Hibernate中文API

    1.2. 第一部分 - 第一个Hibernate应用程序 首先我们将创建一个简单的基于控制台的(console-based)Hibernate应用程序。由于我们使用Java数据库(HSQL DB),所以不必安装任何数据库服务器。 假设我们希望有一个小...

    BeetlSQL是提供开发高效维护高效运行高效的数据库访问框架

    BeetlSQL的目标是提供开发高效,维护高效,运行高效的数据库访问框架,在一个系统多个库的情况下,提供一致的编写代码方式。支持如下数据平台。传统数据库:MySQL(国内兼容MySQL协议的各种大数据库),MariaDB,Oracle,...

    精通 Hibernate:Java 对象持久化技术详解(第2版).part2

     5.1.2 Hibernate访问持久化类属性的策略  5.1.3 在持久化类的访问方法中加入程序逻辑  5.1.4 设置派生属性  5.1.5 控制insert和update语句  5.2 处理SQL引用标识符  5.3 创建命名策略  5.4 设置数据库Schema...

    Hibernate+中文文档

    16.1.4. 返回多个实体(Returning multiple entities) 16.1.5. 返回非受管实体(Returning non-managed entities) 16.1.6. 处理继承(Handling inheritance) 16.1.7. 参数(Parameters) 16.2. 命名SQL查询 ...

    Hibernate实战(第2版 中文高清版)

    第一部分 从Hibernate和EJB 3.0开始  第1章 理解对象/关系持久化   1.1 什么是持久化   1.1.1 关系数据库   1.1.2 理解SQL   1.1.3 在Java中使用SQL   1.1.4 面向对象应用程序中的持久化   1.2 范式不...

Global site tag (gtag.js) - Google Analytics