第十三章 事务并发处理

         HibernateJDBC的轻量级封装,本身并不具备事务管理能力,在事务管理层,Hibernate将其委托给底层的JDBC或者JTA,以实现事务的管理和调度。

         Hibernate的默认事务处理机制基于JDBCTransaction,也可以通过配置文件设定采用JTA作为事务管理实现。

14.1基于JDBC的事务管理

           这里要注意的是,在sessionFactory.openSession()中,Hibernate会初始化数据库连接,与此同时,将其AutoCommit设为关闭状态,这就是说,从SessionFactory获得session,其自动提交属性就已经被关闭了,下面的代码不会对事务性数据库产生任何效果。

  

	 session=sessionFactory.openSession();

  	 session.save(user);

         session.close();

 

 

如果要使得代码真正作用到数据库,必须显示的调用Transaction指令

  

   session=sessionFactory.openSession();

   Transactiontx = session.beginTransaction();

   session.save(user);

   tx.commit();

   session.close();

 

 

14.2基于JTA的事务管理

          JTA,即JavaTransaction API,译为Java事务API


        JTA允许应用程序执行分布式事务处理——在两个或多个网络计算机资源上访问并且更新数据。JDBC驱动程序的JTA支持极大地增强了数据访问能力。


JTA提供了跨Session的事务管理能力,这是与JDBCTransaction最大的差异。


JDBC事务由Connection管理,也就是说,事务管理实际上是在JDBCConnection中实现,事务周期限于Connection的生命周期之内,对于基于JDBCTransactionHibernate事务管理机制,事务管理在Session所依托的JDBCConnection中实现,事务周期限于Session的生命周期。


 JTA事务管理由JTA容器实现,JTA容器对当前加入事务的众多Connection进行调度,实现其事务性要求,JTA的事务周期可横跨多个JDBCConnection生命周期,同样,对基于JTA事务的HibernateJTA事务横跨多个Session。需要注意的是,参与JTA事务的Connection需避免对事务管理进行干涉,如果采用JTATransaction,就不应该再调用HibernateTransaction功能。


JTA一般用于跨数据库的事务,由应用JTA容器实现。可在tomcat中配置jta。一般JTA整合Spring使用更加方便。


HibernateJTA配置

 

<property name="hibernate.transaction.factory_class">

			org.hibernate.transaction.JTATransactionFactory

		</property>


 

 

你可能感兴趣的:(并发)