java中Hibernate的状态总结

来自:互联网
时间:2021-01-25
阅读:

在Hibernate框架中对象的存在有不同的状态,只有理解了这些状态,才能对Hibernate的工作机制有所认知。主要有四种:瞬时状态、持久化状态、脱管状态和删除态 。都比较好理解,大致可以看作是临时、稳定、半稳定、回收的几种形式,下面就Hibernate的这几种状态带来详细的介绍。

1.瞬时状态

通过new开辟内存空间创建的实体对象,但是它没有纳入hibernate session的管理之中,如果没有变量对它引用,它将会被JVM(垃圾回收器)回收。瞬时状态的对象在内存中是孤立的,它与数据库无任何关联,仅仅是一个信息携带的载体。

一个瞬时状态对象被持久化状态对象引用,它也会自动变为持久化状态对象。例如调用session的save、saveorupdate等方法的时候。

特征:

(1)使用 new 创建出来的对象,没有设置 id 属性

(2)没有被 session 托管,换句话说 对象数据 存放在内存中, 没有存放到 session 缓存中

(3)临时对象数据 与 数据库中的数据 还没任何关联

2.持久化状态

持久化状态对象存在与数据库中的数据关联,它总是与会话状态(Session)和事务(Transaction)关联在一起。当持久化状态对象发生变动时并不会立即执行数据库操作,只有当事务结束时,才会更新数据库,以便保证Hibernate的持久化对象和数据库操作的同步性。

当持久化状态对象变为托管状态对象时,它将不在Hibernate持久层的管理范围之内。

特征:

(1)要么是从数据库中使用 get 或 load 方法查询到的数据对象, 要么是 使用save 或 update 方法数据转变成持久层对象

(2)对象 数据被 session 托管。换句话说 对象数据 在 session 缓存中有一份,在数据库中有相应的记录

3.脱管状态

当持久化对象的Session关闭之后,这个对象就从持久化状态变为托管状态。托管状态的对象仍然在与数据库中的数据关联,但是他并不在Hibernate的Session管辖范围之内。

如果将脱管状态的对象重新关联到某个新的Session上,它将变回持久化状态对象。

特征:

(1)主要是通过 持久状态对象,调用 session.evict() 或 session.clear() 或 session.close() 得到的,也可以new 一个设置 id 值的对象

(2)session 缓存中没有,内存中有的对象(注: 该对象设置了 id 值)

4.删除态

调用session的delete方法时,对象转为删除态。删除态只能等待被回收。

知识点扩展:

Hibernate的检索方式

导航对象图检索(根据已经加载的对象,导航到其他对象。)

 OID检索(按照对象的OID来检索对象。)  HQL检索(使用面向对象的HQL查询语言。)  QBC检索(使用QBC(Qurey By Criteria)API来检索对象。 QBC/QBE离线/在线)  本地SQL检索(使用本地数据库的SQL查询语句。)

包括Hibernate的检索方式,Hibernate中对象的状态,Hibernate的3种检索策略是什么,分别适用于哪种场合,ORM解决的不匹配问题, Hibernate映射继承关系的3种方式,Session的find()方法以及Query接口的区别等方面问题的总结

临时状态(transient):刚刚用new语句创建,还没有被持久化,不处于Session的缓存中。处于临时状态的Java对象被称为临时对象。

持久化状态(persistent):已经被持久化,加入到Session的缓存中。处于持久化状态的Java对象被称为持久化对象。

游离状态(detached):已经被持久化,但不再处于Session的缓存中。处于游离状态的Java对象被称为游离对象。

Hibernate的3种检索策略是什么,分别适用于哪种场合

立即检索

优点:对应用程序完全透明。

缺点:select语句数目多。

适用:类级别。

延迟检索

优点:由应用程序决定加载哪些对象,可以避免执行多余的select语句以及避免加载不需要访问的对象,节省内存空间,提高检索效率。

缺点:应用程序如果要访问游离态的代理类实例,必须保证它在持久化时已经被初始化。

适用:一对多或多对多关联。应用程序不需要立即访问或者根本不会访问的对象。

迫切左外连接检索

优点:对应用程序完全透明,不管对象处于持久化状态还是游离状态,应用程序都可以方便的从一个对象导航到另一个与它相关联的对象。使用了外连接,select语句数目少。

缺点:可能会加载程序不许要访问的对象。复杂的数据库表连接形象检索性能。

适用:一对一或多对一关联。应用程序需要立即访问的对象。数据库系统具有良好的表连接性能。

返回顶部
顶部