Hibernate体系结构(简介)

来源:互联网 发布:matlab 对角矩阵 编辑:程序博客网 时间:2024/05/11 09:03

全面的体系结构方案,将应用从底层的jdbc/jta api抽象出来,而让hibernate来处理这些细节。

 

图中各对象定义如下:

SessionFactory (org.hibernate.SessionFactory)

针对单个数据库映射关系经过编译后的内存镜像,是线程安全的(不可变)。它是生成的Session的工厂,本身要用到ConnectionProvider。该对象可以在进程或集群的级别上,为那些事务之间可以重用的数据库提供可选的二级缓存。

Session (org.hibernate.Session)

表示应用程序与持久化存储层之间交互操作的一个单线程对象,此对象生存期很短。其隐藏了jdbc连接,也是Transaction的工厂。其会持有一个针对持久化的必选(一级)缓存,在遍历对象图或者根据持久化对象标识查找对象时会用到。

持久化的对象及其集合

  带有持久化状态的、具有业务功能的单线程对象,此对象生存期很短。这些对

象可以是普通的JavaBeans/POJO,唯一特殊的是他们正与(仅仅)一个Session

关联。一旦Session被关闭,这些对象就会脱离持久化状态,这样就可被应用程序 的任何层自由使用。(例如:跟表示层打交道的数据传输对象。)

瞬态(transient)各胶管(detached)的对象及其集合

那些目前没有与Session关联的持久化类实例。他们可能是在被应用实例化之后,尚未进行持久化的对象。也可以是因为实例化他们的Session已经被关闭而脱离持久化的对象。

事务Transactionorg.hibernate.Transaction

(可选的)应用程序用来指示原子操作单元范围的对象,它是单线程的,生命周期很短。它通过抽象将应用从底层具体的jdbcjta以及corba事务隔离开。某此情况下,一个Session之内可能包含多个Transaction对象。尽管是否使用该对象是可选的,但无论是底层的api不是使用Transaction对象,事务边界的开启与关闭是不可少的。

ConnectionProviderorg.hibernate.connection.ConnectionProvider

(可选的)生成jdbc连接的工厂(同时也起到连接池的作用)。它通过抽象将应用从底层的DataSourceDriverManager隔离开。仅供开发者扩展/实现用,并不暴露给应用程序使用。

TransactionFactoryorg.hibernate.TransactionFactory

(可选的)生成Transaction对象实例的工厂。仅供开发者扩展/实现用,并不暴露给应用程序使用。

 

2.实例状态

一个持久化类的实例可以处于三种不同的状态中的某一种。这三种状态的定义规则与所谓持久化上下文(persistence context)有关。HibernateSession对象就是这个所谓的持久化上下文:

瞬态(transient

该实例从未与任何持久化上下文关联过。它没有持久化标识值(相当于主键值)。

持久化(persistent

实例目前与某个持久上下文相关联。它拥有持久化标识,并且可能在数据库中有一条对应的记录。对于某个特定的持久化上下文,hibernate保证持久化标识与java标识(其值代表对象在内存中的位置)等价。

胶管(detached

实例曾经与某个持久化上下文发生过关联,不过那个上下文已经被关闭了,或者这个实例是被序列化(serialize)到另外的进程。它拥有持久化标识,并且在数据库中可能存在有一条对应的记录。对于胶管状态的实例,hibernate不保证任何持久化标识和java标识的关系。

原创粉丝点击