您的位置:首页 > 其它

hibernate 三种状态深入分析

2011-07-19 15:06 176 查看
在 Hibernate 中有三种状态,对它的深入理解,才能更好的理解 hibernate 的运行机理,刚开始不太注 意这些概念,后来发现它是重要的。对于理解hibernate , JVM 和 sql 的关系有更好的理解。对于需要持久化的 JAVA 对象,在它的生命周期中有三种状态,而且互相转化。1, 临时状态(Transient): 用 new 创建的对象,它没有持久化,没有处于 Session 中,处于此状态的对象叫临时对象; 2, 持久化状态( Persistent): 已经持久化,加入到了 Session 缓存中。如通过 hibernate 语句保存的对象。 处 于此状态的对象叫持久对象; 3, 游离状态(Detached):持久化对象脱离了Session的对象。 如 Session缓存被清空 的对象。
特点:已经持久化,但不在 Session 缓存中。处于此状态的对象叫游离对象;
×√ 临时状态 ( Transient) 持久化状态 ( Persistent) 游离状态 ( Detached)
是否处于 Session 缓存中 × ×
数据库中是否有对应记录 ×
游离对象和临时对象异同: 两者都不会被 Session 关联,对象属性和数据库可能不一致; 游离对象有持久化对象关闭 Session 而转化而来,在内存中还有对象所以此时就变成游离状态了;

Hibernate 和 SQL的关系: 在操作了 hibernate 的方法如 save() 等后,并没有直接生成 sql 语句,去操作数据库,而是把这些更新存入 Session 中,只有 Session 缓存要被更新时,底层的 sql 语句才能执行,数据存入数据库;

下面举例说明:
一,Session.save(user) 运行机理。
1,把User对象加入缓存中,使它变成持久化对象;
2,选用映射文件指定的标识生成ID;
3,在Session清理缓存时候执行:在底层生成一个insert sql语句,把对象存入数据库;

注 意:在你执行Session.save(user)后,在Session清理缓存前,如果你修改user对象属性值,那么最终存入数据库的值将是最后修改 的值;此过程中ID不能被修改;

二,Session.delete(user)运行过程。
如果user是持久化对象,则执行删除 操作,同样底层数据库的执行条件是:在Session清理缓存时候;
如果user是游离对象:
1,将user对象和Session关联,使之成为持久化对象;
2,然后按照 user 是持久化对象的过程执行;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: