Hibernate学习之常用方法比较

一、save()和persist()方法

    使用 save() 方法保存持久化对象时,该方法返回该持久化对象的标识属性值(即对应记录的主键值);但使用 persist() 方法来保存持久化对象时,该方法没有任何返回值。因为 save() 方法需要立即返回持久化对象的标识属性,所以程序执行 save() 会立即将持久化对象对应的数据插入数据库;而 persist() 则保证当它在一个事物外部被调用时,并不立即转换成 insert 语句, 这个功能是很有用的,尤其当我们封装一个长会话流程的时候,persist() 方法就显得尤为重要了。  

主要内容区别:
1,persist把一个瞬态的实例持久化,但是并"不保证"标识符(identifier主键对应的属性)被立刻填入到持久化实例中,标识符的填入可能被推迟到flush的时候。

2,save, 把一个瞬态的实例持久化标识符,及时的产生,它要返回标识符,所以它会立即执行Sql insert

二、get()和load()方法

1、get()方法

(1)ession.get()、query.list()总是会进行立即检索,get()方法不支持延迟加载策略;

(2)如果没有搜索到相关对象,返回一个null,当想判断实例是否存在时,用get。

2、load()方法

(1)如果Session缓存中没有相关对象,load并不立即查询数据库,不执行select,仅返回BO的一个代理类实例:这个代理类扩展自BO类,由Hibernate在运行时使用CGLIB工具动态产生;代理类实例仅初始化OID属性,其他属性都是null,第一次访问BO属性非ID属性)时,Hibernate会执行select+初始化代理类实例

(2)若select查不到,则抛ObjectNotFoundException,getId()并不能触发查询。

(3)load方法支持延迟加载策略,这种延迟初始化能够节省数据库查询,提高性能。

三、update()和saveOrUpdate()

1、update()

      Session 的 update() 方法使一个游离对象转变为持久化对象, 并且计划执行一条 update 语句,若希望 Session 仅当修改了 News 对象的属性时,才执行 update() 语句,,可以把映射文件中 <class> 元素的 select-before-update 设为 true. 该属性的默认值为 false;当 update() 方法关联一个游离对象时, 如果在 Session 的缓存中已经存在相同 OID 的持久化对象, 会抛出异常;当 update() 方法关联一个游离对象时, 如果在数据库中不存在相应的记录, 也会抛出异常.
2、saveOrUpdate()
       Session 的 saveOrUpdate() 方法同时包含了 save() 与 update() 方法的功能,判定对象为临时对象的标准,Java 对象的 OID 为 null,映射文件中为 <id> 设置了 unsaved-value  属性, 并且 Java 对象的 OID 取值与这个 unsaved-value 属性值匹配

四、clear()和flush()

1、clear()
无论是Load 还是 get 都会首先查找缓存(一级缓存),如果没有,才会去数据库查找,调用Clear() 方法,可以强制清除Session缓存。
2、flush()
      可以强制进行从内存到数据库的同步,Flush方法是可以设置的,也就是 fulsh 什么时候执行是可以设置的 在session.beginTransaction 前设置 FlushMode
session.setFlushMode(FlushMode.Always|AUTO|COMMIT|NEVER|MANUAL), 有个好处是可以节省开销,比如默认 session 只做查询时,
就可以不让他与数据库同步了。 session.evict(obj) :会把指定的缓冲对象进行清除。 session.clear() :把缓冲区内的全部对象清除,但不包括操作中的对象。
       flush方法的主要作用就是清理缓存,强制数据库与Hibernate缓存同步,以保证数据的一致性。它的主要动作就是向数据库发送一系列的sql语句,并执行这些sql语句,但是不会向数据库提交。而commit方法则会首先调用flush方法,然后提交事务。这就是为什么我们仅仅调用flush的时候记录并未插入到数据库中的原因,因为只有提交了事务,对数据库所做的更新才会被保存下来。因为commit方法隐式的调用了flush,所以一般我们都不会显示的调用flush方法。这是hibernate的flush机制。在一些复杂的对象更新和保存的过程中就要考虑数据库操作顺序的改变以及延时flush是否对程序的结果有影响。如果确实存在着影响,那就可以在需要保持这种操作顺序的位置加入flush强制Hibernate将缓存中记录的操作flush入数据库,这样看起 来也许不太美观,但很有效。

你可能感兴趣的:(Hibernate)