概述Hibernate访问数据库时加载过程

开发 后端
这里介绍Hibernate访问数据库时加载过程,包括Hibernate将所有系统环境变量(System.getProperties())也添加到GLOBAL_PROPERTIES里面。

Hibernate有很多值得学习的地方,这里我们主要介绍Hibernate访问数据库时加载过程,包括介绍关系数据库表的映射文件等方面。

Hibernate访问数据库时加载过程

对于大多数使用Hibernate的朋友来说,通常使用一下方式来获得Configuration实例:

  1. Configuration configure = new Configuration().configure(); 

在Hibernate中,Configuration是Hibernate的入口。在实例化一个Configuration的时候,Hibernate会自动在环境变量(classpath)里面查找Hibernate配置文件Hibernate.properties。如果该文件存在,则将该文件的内容加载到一个Properties的实例GLOBAL_PROPERTIES里面,如果不存在,将打印信息

  1. 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()会依次访问以下几个元素的内容

  1. <mapping>  
  2. <jcs-class-cache>  
  3. <jcs-collection-cache>  
  4. <collection-cache> 

其中< mapping>是必不可少的,必须通过配置< mapping>,configure()才能访问到我们定义的java对象和关系数据库表的映射文件(hbm.xml),例如:

  1. <mapping resource="Cat.hbm.xml"/> 

这样configure()方法利用各种资源就创建了一个Configuration实例。对于整个项目来说,如果用一个本地线程来存放这个 Configuration实例,那么整个项目只需要实例化一次Configuration对象(注:Configuration实例很花费时间),也就提高了项目的效率。以上介绍Hibernate访问数据库时加载过程。

【编辑推荐】

  1. Hibernate对数据索引进行缓存
  2. 剖析Hibernate主键生成几种常用方式
  3. 浅析Hibernate实现实体对象延迟加载
  4. Hibernate集合类型的延迟加载特性
  5. 概括Hibernate属性延迟加载
责任编辑:佚名 来源: IT168
相关推荐

2009-07-02 09:35:02

hibernate访问

2009-09-28 13:33:48

Hibernate访问

2009-09-25 13:18:15

Hibernate数据

2009-09-24 14:12:22

Hibernate数据

2009-09-18 13:58:00

LINQ查询数据库

2011-03-07 13:30:53

Oracle数据库

2011-05-24 14:27:42

2010-04-16 13:34:00

Oracle Java

2009-06-24 07:53:47

Hibernate数据

2010-05-24 18:16:52

MySQL数据库

2011-03-10 11:12:59

数据库

2009-03-09 17:46:16

ASP.NETSQLOracle

2011-05-20 10:30:20

ORACLE数据库性能优化

2011-08-12 13:18:30

Oracle数据库存储过程

2009-06-29 08:48:41

Hibernate缓存

2009-09-29 16:04:29

Hibernate S

2009-06-17 14:55:26

Hibernate数据

2009-06-24 07:58:52

Hibernate多数

2009-06-02 14:36:28

HibernateMySQLEclipse

2010-05-31 17:15:39

MySQL数据库
点赞
收藏

51CTO技术栈公众号