对象三种状态
瞬时(transient)数据库中没有数据与之对应超过作用域会被JVM垃圾回收器回收一般是new出来且与session没有关联的对象
持久(persistent)数据库中可能有数据与之对应(save)当前与session有关联并且相关联的session没有关闭事务没有提交持久对象状态发生改变在事务提交时会影响到数据库(hibernate能检测到)
脱管(detached)数据库中可能有数据与之对应但当前没有session与之关联但是有oid;托管对象状态发生改变hibernate不能检测到
怎么样判断
是否与session有关数据库是否有记录
三种状态的转换
瞬时状态
通过new语句刚创建了一个java对象他处于临时状态此时不和数据库中的任何记录对应
持久状态
session的save()方法瞬时对象>转变为持久化对象
session的load()方法和get()方法返回的对象总是处于持久化状态
session的update()saveOrUpdate()lock()游离对象>持久化对象
当一个持久化对象关联一个临时对象在允许级联保存的情况下session在清理缓存时会把这个临时对象转变为持久化对象
游离状态
当调用session的close()方法时session的缓存被清空缓存中的所有持久化对象变为游离对象如果在应用程序中没有引用变量引用这些游离对象他们就会结束生命周期
session的evict()方法能够从缓存中删除一个持久化对象使他变为游离状态
图像说明三者关系
save瞬时状态>持久状态
update游离状态>持久状态
saveOrRpdate无法判断是瞬时还是游离可调用此方法变为持久状态会自动判断是瞬时还是游离
游离状态有可能会出现数据库没有信息了但是仍旧有oid会出现删除状态
如何判断对象状态
操纵持久化对象
save()
Session 的 save() 方法使一个临时对象转变为持久化对象
Session 的 save() 方法完成以下操作:
把 News 对象加入到 Session 缓存中 使它进入持久化状态
选用映射文件指定的标识符生成器 为持久化对象分配唯一的 OID 在使用代理主键的情况下 setId() 方法为 News 对象设置 OID 使无效的(一般自动生成)
Hibernate 通过持久化对象的 OID 来维持它和数据库相关记录的对应关系 当 News 对象处于持久化状态时 不允许程序随意修改它的 ID(如何插入表中的对应关系)
计划执行一条 insert 语句把Customer对象当前的属性值组装到insert语句中只有当session清理缓存时才会执行SQL insert语句如果在save()方法之后修改了持久化对象的属性值session清理缓存时会额外执行SQL update语句(如下例)
在行下添加修改姓名的代码判断真正插入到数据库里的是什么
结果如下
【原理解释】
new出来的对象变成持久化状态user与session关联user发生的任何变化hibernate都知道save出来的user还没有插入到数据库中表中最终保存下来的是abc
update()
Session 的 update() 方法使一个游离对象转变为持久化对象 并且计划执行一条 update 语句
saveOrupdate()
该方法同时包含save和update方法如果参数是临时对象就用save方法如果是游离对象就用update方法如果是持久化对象就直接返回