一、 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();
分享到:
相关推荐
这个附件中存放了从配置hibernate 访问Access数据库所需要的JDBC驱动和言语库以及一个配置模板。只需要作一点修改就可以使用了。 注意要使用该库需要使用jdk1.6及hibernate3.5以上版本。
Hibernate 访问 多个数据库
hibernate数据库访问接口设计
使用Hibernate访问数据库,demo中数据库使用的是sqlserver
hibernate中访问access数据库需要的jar包hibernate2access
SpringMVC4.3+Spring+HIbernate4.3简单数据库实例 亲测可用 新建数据库 ssh_person,运行后表自动创建 jdk 8 ,tomcat 8, eclipse 访问 http://localhost:8080/SpringMVC_Spring_Hibernate/
基于Spring与Hibernate的数据库访问技术研究
利用Myeclipse简化基于Hibernate的数据库访问.pdf
NULL 博文链接:https://wjy320.iteye.com/blog/2007115
Hibernate数据库操作实例.zip,博客:http://blog.csdn.net/Peng_Hong_fu/article/details/53229450
很详细,很强大的技术资料,里面包括所有Hibernate的资料
访问数据库基本封装(spring/hibernate/ibatis)
hibernate java o/r mapping
jpa-hibernate-dm: 数据库为{国产达梦数据库},持久层技术为jpa-hibernate mybatis-dm: 数据库为{国产达梦数据库},持久层技术为mybatis mybatis-plus-dm: 数据库为{国产达梦数据库},持久层技术为mybatis-plus 补充...
怎样配置数据库的访问信息,以及映射文件,等配置的示例代码,简洁一看就懂!!!!!
写了一个通用java访问数据库操作的DAO类,非常简单,非常强大,非常方便,非常好用。绝对原版,绝对原创。把hibernate彻底扔掉。(根据C#改编的,原本我是搞C#开发的)
Hibernate Reactive来访问数据库, 编写Java代码以数据模型, 编写React式数据访问代码,以及 程序。 我们建议您从这里开始! 范例程序 目录中有一个非常简单的示例程序。 Gradle构建 该项目是建立与Gradle,但...
用Hibernate对象持久化服务简化Java数据库访问 用Hibernate对象持久化服务简化Java数据库访问
H ibernate是一个实现对象/关系映射的开源框架,它在Java对象和关系数据库中数据之间建立相应的映射关系,简化了数据库访问操作。将此框架应用于移动GSM电子运行维护系统中,可充分发挥其优点,提高系统开发效率。