您好,登錄后才能下訂單哦!
本篇內容主要講解“Hibernate事務管理機制是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Hibernate事務管理機制是什么”吧!
JTA 提供了跨Session 的事務管理能力。這一點是與JDBC Transaction ***的差異。JDBC 事務由Connnection管理,也就是說,事務管理實際上是在JDBC Connection中實現。事務周期限于Connection的生命周期之類。同樣,對于基于JDBC Transaction的Hibernate事務管理機制而言,事務管理在Session 所依托的JDBC Connection中實現,事務周期限于Session的生命周期。
JTA事務管理則由 JTA 容器實現,JTA 容器對當前加入事務的眾多Connection 進行調度,實現其事務性要求。JTA的事務周期可橫跨多個JDBC Connection生命周期。同樣對于基于JTA事務的Hibernate而言,JTA事務橫跨可橫跨多個Session。JTA 事務是由JTA Container 維護,而參與事務的Connection無需對事務管理進行干涉。這也就是說,如果采用JTA Transaction,我們不應該再調用HibernateTransaction功能。
上面基于JDBC Transaction的正確代碼,這里就會產生問題:
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中,我們接連調用了ClassA.saveUser方法和ClassB.saveOrder 方法,同時引入了JTA 中的UserTransaction 以實現ClassC.save方法中的事務性。問題出現了,ClassA 和ClassB 中分別都調用了Hibernate 的Transaction 功能。在Hibernate 的JTA 封裝中,Session.beginTransaction 同樣也執行了InitialContext.lookup方法獲取UserTransaction實例,Transaction.commit方法同樣也調用了UserTransaction.commit方法。
實際上,這就形成了兩個嵌套式的JTA Transaction:ClassC 申明了一個事務,而在ClassC 事務周期內,ClassA 和ClassB也企圖申明自己的事務,這將導致運行期錯誤。因此,如果決定采用JTA Transaction,應避免再重復調用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容器將自動維護此方法執行過程中的事務:
/** * @ejb.interface-method * view-type="remote" * * @ejb.transaction type = "Required" **/ public void save(){ //EJB環境中,通過部署配置即可實現事務申明,而無需顯式調用事務 classA.save(user); classB.save(log); } //方法結束時,如果沒有異常發生,則事務由EJB容器自動提交。
到此,相信大家對“Hibernate事務管理機制是什么”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。