Hibernate持久化类

网友投稿 507 2022-11-06

Hibernate持久化类

Hibernate持久化类

持久化类(Persistent Object )简称 PO,在 Hibernate 中, PO 是由 POJO(即 java 类或实体类)和 hbm 映射配置组成。

简单点说,持久化类本质上就是一个与数据库表建立了映射关系的普通 Java 类(实体类),例如 User 类与数据库中 user 表通过映射文件 User.hbm.xml 建立了映射关系,此时 User 就是一个持久化类。

持久化类的规范

持久化类需要遵守一定的规范,具体如下:

持久化类中需要提供一个使用 public 修饰的无参构造器;持久化类中需要提供一个标识属性 OID,与数据表主键字段向对应,例如实体类 User 中的 id 属性。为了保证 OID 的唯一性,OID 应该由 Hibernate 进行赋值,尽量避免人工手动赋值;持久化类中所有属性(包括 OID)都要与数据库表中的字段相对应,且都应该符合 JavaBean 规范,即属性使用 private 修饰,且提供相应的 setter 和 getter 方法;标识属性应尽量使用基本数据类型的包装类型,例如 Interger,目的是为了与数据库表的字段默认值 null 保持一致;不能用 final 修饰持久化类。

持久化对象

“持久化对象”就是持久化类的实例对象,它与数据库表中一条记录相对应,Hibernate 通过操作持久化对象即可实现对数据库表的 CRUD 操作。

持久化对象的状态

Hibernate 是一款持久层的 ORM 框架,专注于数据的持久化工作。在进行数据持久化操作时,持久化对象可能处于不同的状态当中,这些状态可分为三种,分别为瞬时态、持久态和脱管态,如下表。

状态

别名

产生时机

特点

瞬时态(transient)

临时态或自由态

由 new 关键字开辟内存空间的对象(即使用 new 关键字创建的对象)

  • 没有唯一标识 OID;
  • 未与任何 Session 实例建立关联关系;
  • 数据库中也没有与之相关的记录;

持久态(persistent)

-

当对象加入到 Session 的一级缓存中时,与 Session 实例建立关联关系时

  • 存在唯一标识 OID,且不为 null;
  • 已经纳入到 Session 中管理;
  • 数据库中存在对应的记录;
  • 持久态对象的任何属性值的改动,都会在事务结束时同步到数据库表中。

脱管态(detached)

离线态或游离态

持久态对象与 Session 断开联系时

  • 存在唯一标识 OID;
  • 与 Session 断开关联关系,未纳入 Session 中管理;
  • 一旦有 Session 再次关联该脱管对象,那么该对象就可以立马变为持久状态;
  • 脱管态对象发生的任何改变,都不能被 Hibernate 检测到,更不能提交到数据库中。

在 Hibernate 运行时,持久化对象的三种状态可以通过 Session 接口提供的 一系列方法进行转换。这三种状态之间的转换关系具体如下图。

图1:Hibernate 持久化对象状态转化图

通过上图可知,持久化对象的状态转换遵循以下规则:

当一个实体类对象通过 new 关键字创建时,此时该对象就处于瞬时态。当执行 Session 接口提供的 save() 或 saveOrUpate() 方法,将瞬时态对象保存到 Session 的一级缓存中时,该对象就从瞬时态转换为了持久态。当执行 Session 接口提供的 evict()、close() 或 clear() 方法,将持久态对象与 Session 断开关联关系时,该对象就从持久态转换为了脱管态。当执行 Session 接口提供的 update()、saveOrUpdate() 方法,将脱管态对象重新与 Session 建立关联关系时,该对象会从脱管态转换为持久态。直接执行 Session 接口提供的 get()、load() 或 find() 方法从数据库中查询出的对象,是处于持久态的。当执行 Session 接口提供的 delete() 方法时,持久态对象就会从持久态转换为瞬时态。由于瞬时态和脱管态对象都不在 Session 的管理范围内,因此一段时间后,它们就会被 JVM 回收。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:2020-11-19 Rust1.48稳定版发布!
下一篇:【每周一库】- toml 一个toml文件解析库
相关文章

 发表评论

暂时没有评论,来抢沙发吧~