hibernate中find,iterator;merge,saveOrUpdate,lock的区别
1.find,iterator
(1) iterator首先会获取符合条件的记录的id,再跟据id在本地缓存中查找数据,查找不到的再在数据库中查找,结果再存在缓存中。N+1条SQL。
(2)find跟据生成的sql语句,直接访问数据库,查到的数据存在缓存中,一条sql。
2.Hibernate生成的DAO类中函数功能说明(merge,saveOrUpdate,lock)
/**
* 将传入的detached状态的对象的属性复制到持久化对象中,并返回该持久化对象。
* 如果该session中没有关联的持久化对象,加载一个。
* 如果传入对象未保存,保存一个副本并作为持久对象返回,传入对象依然保持detached状态。
*/
public Sysuser merge(Sysuser detachedInstance) {
log.debug("merging Sysuser instance");
try {
Sysuser result = (Sysuser) getHibernateTemplate().merge(
detachedInstance);
log.debug("merge successful");
return result;
} catch (RuntimeException re) {
log.error("merge failed", re);
throw re;
}
}
/**
* 将传入的对象持久化并保存。 如果对象未保存(Transient状态),调用save方法保存。
* 如果对象已保存(Detached状态),调用update方法将对象与Session重新关联。
*/
public void attachDirty(Sysuser instance) {
log.debug("attaching dirty Sysuser instance");
try {
getHibernateTemplate().saveOrUpdate(instance);
log.debug("attach successful");
} catch (RuntimeException re) {
log.error("attach failed", re);
throw re;
}
}
/**
* 将传入的对象状态设置为Transient状态
*/
public void attachClean(Sysuser instance) {
log.debug("attaching clean Sysuser instance");
try {
getHibernateTemplate().lock(instance, LockMode.NONE);
log.debug("attach successful");
} catch (RuntimeException re) {
log.error("attach failed", re);
throw re;
}
}