新聞中心
在向大家詳細介紹Hibernate事務管理機制之前,首先讓大家了解下JTA事務管理,然后全面介紹Hibernate事務管理機制。

站在用戶的角度思考問題,與客戶深入溝通,找到郯城網(wǎng)站設計與郯城網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都做網(wǎng)站、成都網(wǎng)站建設、成都外貿(mào)網(wǎng)站建設、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、空間域名、雅安服務器托管、企業(yè)郵箱。業(yè)務覆蓋郯城地區(qū)。
JTA 提供了跨Session 的事務管理能力。這一點是與JDBC Transaction ***的差異。JDBC 事務由Connnection管理,也就是說,事務管理實際上是在JDBC Connection中實現(xiàn)。事務周期限于Connection的生命周期之類。同樣,對于基于JDBC Transaction的Hibernate事務管理機制而言,事務管理在Session 所依托的JDBC Connection中實現(xiàn),事務周期限于Session的生命周期。
JTA事務管理則由 JTA 容器實現(xiàn),JTA 容器對當前加入事務的眾多Connection 進行調(diào)度,實現(xiàn)其事務性要求。JTA的事務周期可橫跨多個JDBC Connection生命周期。同樣對于基于JTA事務的Hibernate而言,JTA事務橫跨可橫跨多個Session。JTA 事務是由JTA Container 維護,而參與事務的Connection無需對事務管理進行干涉。這也就是說,如果采用JTA Transaction,我們不應該再調(diào)用HibernateTransaction功能。
上面基于JDBC Transaction的正確代碼,這里就會產(chǎn)生問題:
- public class ClassA{
- public void saveUser(User user){
- session = sessionFactory.openSession();
- Transaction tx = session.beginTransaction();
- session.save(user);
- tx.commit();
- session.close();
- }
- }
- public class ClassB{
- public void saveOrder(Order order){
- session = sessionFactory.openSession();
- Transaction tx = session.beginTransaction();
- session.save(order);
- tx.commit();
- session.close();
- }
- }
- public class ClassC{
- public void save(){
- ……
- UserTransaction tx = new InitialContext().lookup(“……”);
- ClassA.save(user);
- ClassB.save(order);
- tx.commit();
- ……
- }
- }
這里有兩個類ClassA和ClassB,分別提供了兩個方法:saveUsersaveOrder,用于保存用戶信息和訂單信息。在ClassC中,我們接連調(diào)用了ClassA.saveUser方法和ClassB.saveOrder 方法,同時引入了JTA 中的UserTransaction 以實現(xiàn)ClassC.save方法中的事務性。問題出現(xiàn)了,ClassA 和ClassB 中分別都調(diào)用了Hibernate 的Transaction 功能。在Hibernate 的JTA 封裝中,Session.beginTransaction 同樣也執(zhí)行了InitialContext.lookup方法獲取UserTransaction實例,Transaction.commit方法同樣也調(diào)用了UserTransaction.commit方法。
實際上,這就形成了兩個嵌套式的JTA Transaction:ClassC 申明了一個事務,而在ClassC 事務周期內(nèi),ClassA 和ClassB也企圖申明自己的事務,這將導致運行期錯誤。因此,如果決定采用JTA Transaction,應避免再重復調(diào)用Hibernate 的Transaction功能,上面的代碼修改如下:
- public class ClassA{
- public void save(TUser user){
- session = sessionFactory.openSession();
- session.save(user);
- session.close();
- }
- ……
- }
- public class ClassB{
- public void save (Order order){
- session = sessionFactory.openSession();
- session.save(order);
- session.close();
- }
- ……
- }
- public class ClassC{
- public void save(){
- ……
- UserTransaction tx = new InitialContext().lookup(“……”);
- classA.save(user);
- classB.save(order);
- tx.commit();
- ……
- }
- }
上面代碼中的ClassC.save方法,也可以改成這樣:
- public class ClassC{
- public void save(){
- ……
- session = sessionFactory.openSession();
- Transaction tx = session.beginTransaction();
- classA.save(user);
- classB.save(order);
- tx.commit();
- ……
- }
- }
實際上,這是利用Hibernate來完成啟動和提交UserTransaction的功能,但這樣的做法比原本直接通過InitialContext獲取UserTransaction 的做法消耗了更多的資源,得不償失。
在EJB 中使用JTA Transaction 無疑最為簡便,我們只需要將save 方法配置為JTA事務支持即可,無需顯式申明任何事務,下面是一個Session Bean的save方法,它的事務屬性被申明為“Required”,EJB容器將自動維護此方法執(zhí)行過程中的事務:
- /**
- * @ejb.interface-method
- * view-type="remote"
- *
- * @ejb.transaction type = "Required"
- **/
- public void save(){
- //EJB環(huán)境中,通過部署配置即可實現(xiàn)事務申明,而無需顯式調(diào)用事務
- classA.save(user);
- classB.save(log);
- }
- //方法結(jié)束時,如果沒有異常發(fā)生,則事務由EJB容器自動提交。
以上介紹Hibernate事務管理機制。
【編輯推薦】
- 描述Hibernate檢查id字段
- Hibernate Template簡單描述
- Hibernate DetachedCriteria學習經(jīng)驗
- 概述Hibernate equals()方法
- Hibernate使用Person對象
分享名稱:Hibernate事務管理機制剖析
標題路徑:http://www.dlmjj.cn/article/djssjip.html


咨詢
建站咨詢
