• hibernate中load,get;find,iterator;merge,saveOrUpdate,lock的区别


    hibernate中load,get;find,iterator;merge,saveOrUpdate,lock的区别

    转自http://www.blogjava.net/bnlovebn/archive/2007/07/13/130025.html

    一、load,get
    (1)当记录不存在时候,get方法返回null,load方法产生异常

    (2)load方法可以返回实体的代理类,get方法则返回真是的实体类

    (3)load方法可以充分利用hibernate的内部缓存和二级缓存中的现有数据,而get方法仅仅在内部缓存中进行数据查找,如果没有发现数据則将越过二级缓存,直接调用SQL查询数据库。
    (4)也许别人把数据库中的数据修改了,load如何在缓存中找到了数据,则不会再访问数据库,而get则会返回最新数据。

    二、find,iterator
    (1) iterator首先会获取符合条件的记录的id,再跟据id在本地缓存中查找数据,查找不到的再在数据库中查找,结果再存在缓存中。N+1条SQL。
     (2)find跟据生成的sql语句,直接访问数据库,查到的数据存在缓存中,一条sql。

    三、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;
    }
    }

  • 相关阅读:
    洛谷P2331 [SCOI2005]最大子矩阵 DP
    洛谷P2216: [HAOI2007]理想的正方形 单调队列优化DP
    牛客练习赛38 E 出题人的数组 2018ccpc桂林A题 贪心
    zstu19一月月赛 duxing201606的原味鸡树
    gym/102021/J GCPC18 模拟拼图
    gym/102021/K GCPC18 背包dp算不同数和的可能
    洛谷 P2051 [AHOI2009]中国象棋 状态压缩思想DP
    洛谷 P1070 道路游戏 DP
    洛谷P2577 [ZJOI2005]午餐 打饭时间作为容量DP
    动态规划:插头DP
  • 原文地址:https://www.cnblogs.com/new0801/p/6175990.html
Copyright © 2020-2023  润新知