Hibernate之Session刷出(flush)
什么是Hibernate Session刷出(flush)?也許大家對此不夠了解,但相信你看完本文一定有很大的收益。
每間隔一段時間,Session會執(zhí)行一些必需的SQL語句來把內(nèi)存中的對象的狀態(tài)同步到JDBC連接中。這個過程被稱為Hibernate Session刷出(flush),默認會在下面的時間點執(zhí)行:
◆在某些查詢執(zhí)行之前
◆在調(diào)用org.hibernate.Transaction.commit()的時候
◆在調(diào)用Session.flush()的時候
◆涉及的SQL語句會按照下面的順序發(fā)出執(zhí)行:
◆所有對實體進行插入的語句,其順序按照對象執(zhí)行Session.save()的時間順序
◆所有對實體進行更新的語句
◆所有進行集合刪除的語句
◆所有對集合元素進行刪除,更新或者插入的語句
◆所有進行集合插入的語句
◆所有對實體進行刪除的語句,其順序按照對象執(zhí)行Session.delete()的時間順序
(有一個例外是,如果對象使用native方式來生成ID(持久化標識)的話,它們一執(zhí)行save就會被插入。)
除非你明確地發(fā)出了flush()指令,關(guān)于Session何時會執(zhí)行這些JDBC調(diào)用是完全無法保證的,只能保證它們執(zhí)行的前后順序。 當然,Hibernate保證,Query.list(..)絕對不會返回已經(jīng)失效的數(shù)據(jù),也不會返回錯誤數(shù)據(jù)。
也可以改變默認的設(shè)置,來讓Hibernate Session刷出(flush)操作發(fā)生的不那么頻繁。 FlushMode類定義了三種不同的方式。 僅在提交時刷出(僅當Hibernate的Transaction API被使用時有效), 按照剛才說的方式刷出, 以及除非明確使用flush()否則從不刷出。 最后一種模式對于那些需要長時間保持Session為打開或者斷線狀態(tài)的長時間運行的工作單元很有用。
- sess = sf.openSession();
- Transaction tx = sess.beginTransaction();
- sess.setFlushMode(FlushMode.COMMIT); // allow queries to return stale state
- Cat izi = (Cat) sess.load(Cat.class, id);
- izi.setName(iznizi);
- // might return stale data
- sess.find("from Cat as cat left outer join cat.kittens kitten");
- // change to izi is not flushed!
- ...
- tx.commit(); // flush occurs
- sess.close();
Hibernate Session刷出(flush)期間,可能會拋出異常。(例如一個DML操作違反了約束) 異常處理涉及到對Hibernate事務性行為的理解,這里在事務和并發(fā)中有具體的介紹,這里我們就不加以介紹了。