`

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();


分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics