本站首页    管理页面    写新日志    退出


«August 2025»
12
3456789
10111213141516
17181920212223
24252627282930
31


公告
 本博客在此声明所有文章均为转摘,只做资料收集使用。

我的分类(专题)

日志更新

最新评论

留言板

链接

Blog信息
blog名称:
日志总数:1304
评论数量:2242
留言数量:5
访问次数:7591502
建立时间:2006年5月29日




[Hibernate]Hibernate访问多个数据库
软件技术

lhwork 发表于 2006/12/22 16:14:06

一、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,多数据库就更简单了,像这段代码可以完成所有配置: jdbc:mysql://localhost:3306/test org.gjt.mm.mysql.Driver root 123 org.hibernate.dialect.MySQLDialect test.hbm.xml jdbc:odbc:test sun.jdbc.odbc.JdbcOdbcDriver root 123 org.hibernate.dialect.SQLServerDialect test.hbm.xml ....... 以上只是配置Hibernate访问多个数据库的一般方法,hibernate还有很多可行的配置,有兴趣的读者可以参考它的reference。


阅读全文(1764) | 回复(0) | 编辑 | 精华
 



发表评论:
昵称:
密码:
主页:
标题:
验证码:  (不区分大小写,请仔细填写,输错需重写评论内容!)



站点首页 | 联系我们 | 博客注册 | 博客登陆

Sponsored By W3CHINA
W3CHINA Blog 0.8 Processed in 0.359 second(s), page refreshed 144774241 times.
《全国人大常委会关于维护互联网安全的决定》  《计算机信息网络国际联网安全保护管理办法》
苏ICP备05006046号