现在的位置: 首页 > 综合 > 正文

merge,attachDirty,attachClean

2013年10月02日 ⁄ 综合 ⁄ 共 1669字 ⁄ 字号 评论关闭

public Person merge(Person detachedInstance) {

log.debug("merging Person instance");

try {

Person result = (Person) getSession().merge(

detachedInstance);

log.debug("merge successful");

return result;

} catch (RuntimeException re) {

log.error("merge failed", re);

throw re;

}

}

 

public void attachDirty(Person instance) {

log.debug("attaching dirty Person instance");

try {

getSession().saveOrUpdate(instance);

log.debug("attach successful");

} catch (RuntimeException re) {

log.error("attach failed", re);

throw re;

}

}

 

public void attachClean(Person instance) {

log.debug("attaching clean Person instance");

try {

getSession().lock(instance, LockMode.NONE);

log.debug("attach successful");

} catch (RuntimeException re) {

log.error("attach failed", re);

throw re;

}

}

attachDirty:将传入的对象持久化并保存。如果对象未保存(Transient状态),调用save方法保存。如果对象已保存(Detached状态),调用update方法将对象与Session重新关联。 

attachClean:将传入的对象状态设置为Transient状态。 

说明一下,在Hibernate中的对象有三种状态,即: 
瞬时状态(Transient)、持久状态(Persistent)、脱管状态(Detached) 

1、瞬时状态(Transient) 
由new命令开辟内存空间的Java对象,也就是平时所熟悉的普通Java对象。 

如:Person p = new Person(); 
瞬时对象特点: 
(1)不和Session实例关联 
(2)在数据库中没有和瞬时对象关联的记录 

2、持久状态(Persistent) 
持久的实例在数据库中有对应的记录,并拥有一个持久化标识(identifier). 
持久对象总是与Session和Transaction相关联,在一个Session中,对持久对象的改变不会马上对数据库进行变更,而必须在Transaction终止,也就是执行commit()之后,才在数据库中真正运行SQL进行变更,持久对象的状态才会与数据库进行同步。在同步之前的持久对象称为脏(dirty)对象。 
瞬时对象转为持久对象: 
(1) 通过Session的save()和saveOrUpdate()方法把一个瞬时对象与数据库相关联,这个瞬时对象就成为持久化对象。 
(2) 使用fine(),get(),load()和iterater()待方法查询到的数据对象,将成为持久化对象。 
持久化对象的特点: 
(1) 和Session实例关联 
(2) 在数据库中有和持久对象关联的记录 

3、脱管状态(Detached) 
与持久对象关联的Session被关闭后,对象就变为脱管对象。对脱管对象的引用依然有效,对象可继续被修改。 
脱管对象特点: 
(1) 本质上和瞬时对象相同 
(2) 只是比爱瞬时对象多了一个数据库记录标识值id. 
持久对象转为脱管对象: 
当执行close()或clear(),evict()之后,持久对象会变为脱管对象。 

瞬时对象转为持久对象: 
通过Session的update(),saveOrUpdate()和lock()等方法,把脱管对象变为持久对象。 

抱歉!评论已关闭.