`
付绍高
  • 浏览: 35853 次
  • 性别: Icon_minigender_1
  • 来自: 江西临川
社区版块
存档分类
最新评论

Spring整合Hibernate

阅读更多

采用声明式事务

 

1、声明式事务配置

 * 配置SessionFactory

 

<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">

  <property name="configLocation">

   <value>classpath:hibernate.cfg.xml</value>

  </property> 

 </bean>           

 

 * 配置事务管理器

 

 

 

<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">

  <property name="sessionFactory">

   <ref bean="sessionFactory"/>

  </property> 

 </bean>

 

 * 事务的传播特性

 

 

<tx:advice id="txAdvice" transaction-manager="transactionManager">

  <tx:attributes>

   <tx:method name="add*" propagation="REQUIRED"/>

   <tx:method name="del*" propagation="REQUIRED"/>

   <tx:method name="modify*" propagation="REQUIRED"/>

   <tx:method name="*" read-only="true"/>

  </tx:attributes>

 </tx:advice>

 

 * 那些类那些方法使用事务

 

 

 

<aop:config>

  <aop:pointcut id="allManagerMethod" expression="execution(* com.fendou.dao.impl. *.*(..))"/>

  <aop:advisor pointcut-ref="allManagerMethod" advice-ref="txAdvice"/>

 </aop:config>

 

 

 

2、编写业务逻辑方法

 * 继承HibernateDaoSupport类,使用HibernateTemplate来持久化,HibernateTemplate

   Hibernate Session的轻量级封装

 * 默认情况下运行期异常才会回滚(包括继承了RuntimeException子类),普通异常是不会滚的

 * 编写业务逻辑方法时,最好将异常一直向上抛出,在表示层(struts)处理

 * 关于事务边界的设置,通常设置到业务层,不要添加到Dao 

 

3、了解事务的几种传播特性PROPAGATION  propagation

 1. REQUIRED: required 如果存在一个事务,则支持当前事务。如果没有事务则开启

 2. SUPPORTS: 如果存在一个事务,支持当前事务。如果没有事务,则非事务的执行

 3. MANDATORY: mandatory 如果已经存在一个事务,支持当前事务。如果没有一个活动的事务,则抛出异常。

 4. REQUIRES_NEW: 总是开启一个新的事务。如果一个事务已经存在,则将这个存在的事务挂起。

 5. NOT_SUPPORTED: 总是非事务地执行,并挂起任何存在的事务。

 6. NEVER: 总是非事务地执行,如果存在一个活动事务,则抛出异常

 7. NESTED:如果一个活动的事务存在,则运行在一个嵌套的事务中. 如果没有活动事务,

      则按TransactionDefinition.PROPAGATION_REQUIRED 属性执行

 

4Spring事务的隔离级别

 1. ISOLATION_DEFAULT 这是一个PlatfromTransactionManager默认的隔离级别,使用数据库默认的事务隔离级别.

      另外四个与JDBC的隔离级别相对应

 2. ISOLATION_READ_UNCOMMITTED 这是事务最低的隔离级别,它充许令外一个事务可以看到这个事务未提交的数据。

      这种隔离级别会产生脏读,不可重复读和幻像读。

 3. ISOLATION_READ_COMMITTED 保证一个事务修改的数据提交后才能被另外一个事务读取。另外一个事务不能读取该事务未提交的数据

 4. ISOLATION_REPEATABLE_READ 这种事务隔离级别可以防止脏读,不可重复读。但是可能出现幻像读。

      它除了保证一个事务不能读取另一个事务未提交的数据外,还保证了避免下面的情况产生(不可重复读)

 5. ISOLATION_SERIALIZABLE 这是花费最高代价但是最可靠的事务隔离级别。事务被处理为顺序执行。

      除了防止脏读,不可重复读外,还避免了幻像读。   

 

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics