`

Hibernate连接多个数据库

    博客分类:
  • Java
 
阅读更多
一、             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();

同时连接两个数据库实例:

问题:连接mssql中的vedio 和bbs数据库

解决方案:

1.vedio.cfg.xml

<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
<session-factory name="bbs">
<!-- 指定连接数据库的用户名 -->
<property name="connection.username">sa</property>
<!-- 指定连接数据库的URL -->
<property name="connection.url">
  jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=vedio; 
</property>
<!-- 指定数据库使用的SQL方言 -->
<property name="dialect">
  org.hibernate.dialect.SQLServerDialect
</property>
<!-- 指定连接数据库的口令 -->
<property name="connection.password">sa</property>
<!-- 指定连接数据库的驱动程序 -->
<property name="connection.driver_class">
  com.microsoft.jdbc.sqlserver.SQLServerDriver
</property>
<!-- true表示程序运行时,在控制台显示SQL语句,false表示不显示SQL语句 -->
<property name="show_sql">true</property>
<!-- <property name="connection.pool_size">50</property> -->

<!-- 持久化类所对应的映射文件 -->
<mapping resource="vedio/Managers.hbm.xml" />


</session-factory>
</hibernate-configuration>



2. bbs.cfg.xml

<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
<session-factory name="bbs">
<!-- 指定连接数据库的用户名 -->
<property name="connection.username">sa</property>
<!-- 指定连接数据库的URL -->
<property name="connection.url">
  jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=bbs; 
</property>
<!-- 指定数据库使用的SQL方言 -->
<property name="dialect">
  org.hibernate.dialect.SQLServerDialect
</property>
<!-- 指定连接数据库的口令 -->
<property name="connection.password">sa</property>
<!-- 指定连接数据库的驱动程序 -->
<property name="connection.driver_class">
  com.microsoft.jdbc.sqlserver.SQLServerDriver
</property>
<!-- true表示程序运行时,在控制台显示SQL语句,false表示不显示SQL语句 -->
<property name="show_sql">true</property>
<!-- <property name="connection.pool_size">50</property> -->

<!-- 持久化类所对应的映射文件 -->
<mapping resource="bbs/Board.hbm.xml" />
<mapping resource="bbs/BBSUser.hbm.xml" />
<mapping resource="bbs/BBSManager.hbm.xml" />
<mapping resource="bbs/Image.hbm.xml" />
<mapping resource="bbs/Upfile.hbm.xml" />
<mapping resource="bbs/Post.hbm.xml" />
<mapping resource="bbs/BestPost.hbm.xml" />
<mapping resource="bbs/User.hbm.xml" />
<mapping resource="bbs/Groups.hbm.xml" />
<mapping resource="bbs/Help.hbm.xml" />
<mapping resource="bbs/Note.hbm.xml" />
<mapping resource="vedio/Managers.hbm.xml" />


</session-factory>
</hibernate-configuration>

3.VedioHibernateUTL.java

package vedio;

import org.hibernate.*;
import org.hibernate.cfg.*;

public class HibernateUtil {

public static final SessionFactory sessionFactory;
  static {
   try{
    sessionFactory=new Configuration().configure("/vedio.cfg.xml").buildSessionFactory();
   
   }catch(Throwable ex) {
   
    throw new ExceptionInInitializerError(ex);
   }
  }

public static final ThreadLocal<Session> session =new ThreadLocal<Session>();

//create session
public static Session currentSession() throws HibernateException {
  Session s= session.get();
  if(s==null||!s.isOpen()) {
   s=sessionFactory.openSession();
   session.set(s);
  }
  return s;
}

//close session
public static void closeSession() throws HibernateException {
  Session s=session.get();
  session.set(null);
  if(s!=null) {
   s.close();
  }
 
}
}




4.BbsHibernateUTL.java

package bbs;

import org.hibernate.*;
import org.hibernate.cfg.*;

public class HibernateUtil {

public static final SessionFactory sessionFactory;
  static {
   try{
    sessionFactory=new Configuration().configure("/bbs.cfg.xml").buildSessionFactory();
   
   }catch(Throwable ex) {
   
    throw new ExceptionInInitializerError(ex);
   }
  }

public static final ThreadLocal<Session> session =new ThreadLocal<Session>();

//create session
public static Session currentSession() throws HibernateException {
  Session s= session.get();
  if(s==null||!s.isOpen()) {
   s=sessionFactory.openSession();
   session.set(s);
  }
  return s;
}

//close session
public static void closeSession() throws HibernateException {
  Session s=session.get();
  session.set(null);
  if(s!=null) {
   s.close();
  }
 
}
}


然后写相应的 表名.hbm.xml文件

总结一下:一人数据源对应一个.cfg.xml文件,一个HibernateUTL.java,对应多个 表名.hbm.xml



如果你用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>
本文转自:http://blog.csdn.net/zhiyi2010/article/details/7644612
分享到:
评论

相关推荐

    hibernate同时配置多个数据库连接

    hibernate同时配置多个数据库连接 可以同时连接不同IP的不同数据库

    spring+hibernate和spring+myBatis实现连接多个数据库,同时操作的项目

    项目中我们经常会遇到多数据源的问题,尤其是数据同步或定时任务等项目更是如此。多数据源让人最头痛的,不是配置多个数据源,而是如何能灵活动态的切换数据源。 此项目就是为了解决这个问题。

    ssh2连接多个数据库

    ssh2连接多个数据库 struts2 hibernate spring 配置连接多个mysql数据库

    针对SSH框架Spring管理Hibernate连接多个数据源配置文件

    该配置文件连接的是两个数据库结构相同的数据源,其他比如数据库结构不原理也可行。本人在遇到此问题时上网搜了很多答案结果都不怎么如意,有的太深奥不过思想很好,有的又太不给力,后来自己慢慢研究配置成功后想与...

    支持多个连接多个数据库的HibernateFactory

    &lt;br&gt;StaticHbmQuery shq = new StaticHbmQuery(\"hibernate.cfg.xml\"); &lt;br&gt;...... &lt;br&gt;//shq.clear(); //java.util.ArrayList arr = shq.hbmQuery([HQL]); //shq.hbmUpdate([Object]); //shq....

    SSH框架调用多个数据库

    SpringMVC+Hibernate+Spring框架搭建的同一项目调用多个数据库。

    springMVC配置连接数据库实现登录功能的一个小demo

    学了几天,配置连接数据库实现登录功能的一个小demo,还有很多地方比较模糊,添加包也是全添,很多细节的问题都在研究中

    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查询 ...

    Spring+Hibernate实现用户登录

    Spring+Hibernate实现用户登录程序,可执行,里面配置文件是正确的,在mysql中见一个wangwei数据库,再建个user表就可执行

    Springboot整合Hibernate thymeleaf,添删改查,分页查询等,单元测试,亲测百分之白可运行

    Springboot整合Hibernate thymeleaf,添删改查,分页查询等,单元测试,亲测百分之百可运行,网上好多功能不全,甚至无法运行,这个是我自己亲自跑的,绝对没有问题

    tomcat/resin使用全局数据库连接池资源

    但是这种方式有一些不足的是当应用服务器配置了多个应用,而这些应用使用同一个数据库,这会导致不必要的资源浪费,也是同一个应用服务器中存在针对同一个数据库的多个连接池。  也是说我们希望每个应用服务器只有...

    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:Java 对象持久化技术详解(第2版).part2

     21.1 多个事务并发运行时的并发问题  21.1.1 第一类丢失更新  21.1.2 脏读  21.1.3 虚读  21.1.4 不可重复读  21.1.5 第二类丢失更新  21.2 数据库系统的锁的基本原理  21.2.1 锁的多粒度性及自动锁升级  ...

    hibernate3.2中文文档(chm格式)

    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查询 ...

    HibernateAPI中文版.chm

    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学习笔记

    hibernate一对多双向自连接关联映射 15 hibernate多对多关联映射(单向User----&gt;Role) 19 hibernate多对多关联映射(双向User&lt;----&gt;Role) 20 Hibernate的继承关系 21 每棵继承树映射成一张表(hibernate_extends_1) 22 ...

    深入浅出Hibernate源码

    (假若您希望使用其它用户名如root,您需要修改hibernate的数据库配置中的连接参数——位于hibernate.cfg.xml中,以及创建数据库表时的连接参数——位于build.xml中。) 7, 确认ant安装正确. ant可以在此下载: ...

    hibernate精华教程

    如果应用同时访问多个DB,怎需要为每个数据库创建一个单独的SessionFactory实例。 (3)Session:也被称为持久化管理器,对象级数据库操作。 特点: 1)不是线程安全的,因此在设计软件架构时,应该避免多个线程共享...

    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查询 ...

Global site tag (gtag.js) - Google Analytics