在向大家详细介绍Hibernate事务管理机制之前,首先让大家了解下JTA事务管理,然后全面介绍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事务管理机制。
【编辑推荐】
网站标题:Hibernate事务管理机制剖析
链接URL:http://www.csdahua.cn/qtweb/news42/32492.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网