采用声明式事务
1、了解事务的传播特性 1、propagation_required:如果当前存在一个事务,则支持当前事务,如果没有事务则开启事务 2、propagation_supports:如果存在一个事务,则支持当前事务,如果没有事务则非事务执行 3、propagation_mandatory:如果存在一个事务,则支持当前事务,如果没有事务则抛出异常 4、propagation_requires_new:总是开启新事务,如果当前存在一个事务,则把当前事务挂起 5、propagation_not_supported:总是非事务执行,总是挂起当前存在的事务 6、propagation_never:总是非事务执行,如果当前存在一个事务,则抛出异常 7、propagation_nested:如果存在一个事务,则运行在一个嵌套的事务中,如果没有活动的事务, 则按TransactionDefinition.propagation_required 属性执行 2、事务的隔离级别 1、isolation_default:这是一个platfromTransactionManager默认的隔离界别,使用数据库默认的事务隔离级别, 另外四个与jdbc的隔离级别相对应 2、isolation_read_uncommitted: 这是事务最低的隔离级别,它允许另外一个事务可以看到这个事务未提交的数据。 这种隔离ijbie会产生脏读,不可重复读和幻像读。 3、isolation_read_committed: 保证一个事务修改的数据提交后才能被另外一个事务读取。另外一个事务不能读取该 事务为提交的数据 4、isolation_repeatable_read: 这种事务隔离界别可以防止脏读,不可重复读。但是可能出现幻像读。 它除了保证一个事务不能读取另外一个未提交的数据外,还保证了避免下面的情况发生(不可重复读)。 5、isolation_serializable 这是花费最高代价但是最可靠的事务隔离级别。事务被处理为顺序执行。 除了防止脏读,不可重复读外,还避免了幻像读。
3、声明式事务配置 * 配置sessionFactory <!-- 配置sesionFactory --> <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.gzbb.usermgr.manager.*.*(..))"/> <aop:advisor pointcut-ref="allManagerMethod" advice-ref="txAdvice"/> </aop:config>
4、编写业务逻辑方法 * 继承HibernateDaoSupport类,使用HibernateTemplate来持久化,HibernateTemplate是 Hibernate,Session的轻量级封装 * 默认情况下运行期异常才回滚(包括RuntimeException的子类),普通异常不会回滚 * 编写业务逻辑层时,最好将异常一直向上抛出,在表示层(struts)处理 * 关于事务边界设置,通常设置到业务层,不要添加到Dao上
采用编程式事务 1、getCurrentSession与openSession的区别 * 采用getCurrentSession创建的session会把当前session绑定到当前线程中,而采用openSession 创建的session则不会 * 采用getCurrentSession创建的session在commit或rollback时就会关闭,而采用openSession 创建的session必须手动关闭 2、使用getCurrentSession需要在hibernate.cfg.xml文件中加如下配置: * 如果使用本地事务(jdbc事务) <property name="hibernate.current_session_context_class">thread</property> * 如果使用全局事务(jta事务) <property name="hibernate.current_session_context_class">jta</property>
转载于:https://www.cnblogs.com/J2EEPLUS/archive/2012/04/27/2488140.html