重庆分公司,新征程启航

为企业提供网站建设、域名注册、服务器等服务

Hibernate事务管理机制是什么

本篇内容主要讲解“Hibernate事务管理机制是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Hibernate事务管理机制是什么”吧!

创新互联长期为数千家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为南澳企业提供专业的成都网站设计、成都网站建设南澳网站改版等技术服务。拥有十多年丰富建站经验和众多成功案例,为您定制开发。

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事务管理机制是什么
转载注明:http://cqcxhl.cn/article/gppcdc.html

其他资讯

在线咨询
服务热线
服务热线:028-86922220
TOP