采用编程式事务
1、 getCurrentSession()与openSession()的区别?
* 采用getCurrentSession()创建的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>
采用声明式事务
声明式事务配置
* 配置SessionFactory
* 配置事务管理器
* 事务的传播特性
* 那些类哪些方法使用事务
2、编写业务逻辑方法
* 继承HibernateDaoSupport类,使用HibernateTemplate类持久化,HibernateTemplate
是Hibernate session的封装
* 默认的回滚是RuntimeException(包括继承RuntimeException的子类),普通异常不回滚
* 在编写业务逻辑方法时,最好将异常一直往上抛出,在呈现层处理(struts)
* spring的事务需要设置到业务方法上(事务边界定义到Facade类上),不要添加到Dao上
3、了解事务的集中传播忒性
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属性执行
4、Spring事务的隔离级别
1、 ISOLATION_DEFAULT: 这是一个PlatfromTransactionManager默认的隔离级别,使用数据库默认的事务隔离级别。
2、ISOLATION_READ_UNCOMMITTED:这是事务最低的隔离级别,它允许另外一个事务可以看到这个事务未提交的数据。
3、ISOLATION_READ_COMMITTED:保证一个事务修改的数据提交后才能被另外一个事务读取。另外一个事务不能读取该事务未提交的数据。
4、ISOLATION_REPEATALBE_READ: 这种事务隔离级别可以防止脏读,不可重复读。但是可能出现幻想读。它除了保证一个事务不能读取另外一个事务未提交的数据外,还保证了避免下面的情况产生(不可重复读)。
5、ISOLATION_SERIALIZABLE 这是花费最高代价但是最可靠的事务隔离级别。事务被处理为顺序执行。除了防止脏读,不课重复读外,还避免了幻想读。
事务属性
T1
T2
Required
无
T1
T2
T1
RequiredNew
无
T1
T2
T2
Support
无
T1
无
T1
Mandatory
无
T1
抛异常
T1
NoSupport
无
T1
无
无
Never
无
T1
无
抛异常
à
<!-- 配置sessionFactory -- >
<bean id=”sessionFacory”class=”org.springframework.orm.hibernate3.LocalSessionFactoryBean”>
<property name=”configLocation”>
<value>classpath:hibernate.cfg.xml</value>
</property>
</bean>
<!-- 配置事务管理器-- >
<beanid=”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.bjsxt.usermgr.manager.*.*(..))”/>
<aop:advisor pointcut-ref=”allManagerMethod” advice-ref=”txAdvice”/>
</aop:config>
分享到:
相关推荐
PROPAGATION_REQUIRED--支持当前事务,如果当前没有事务,就新建一个事务。这是最常见的选择。 PROPAGATION_SUPPORTS--支持当前事务,如果当前没有事务,就以非事务方式执行。 PROPAGATION_MANDATORY--支持当前...
1. **PROPAGATION_REQUIRED**:如果当前存在事务,则加入该事务;如果当前没有事务,则创建一个新的事务。 2. **PROPAGATION_SUPPORTS**:如果当前存在事务,则加入该事务;如果当前没有事务,则以非事务方式执行。 ...
这意味着,当你在一个已有的事务中调用一个PROPAGATION_REQUIRED的方法,这个方法将会成为当前事务的一部分,共享相同的事务上下文。 2. **PROPAGATION_SUPPORTS**:如果当前存在事务,那么就支持它,即在事务内部...
在事务拦截器中,我们可以配置不同的事务属性,例如PROPAGATION_REQUIRED、readOnly等,这些属性将被用来控制事务的行为。例如,在delete、add、update、save操作中,我们使用PROPAGATION_REQUIRED来确保事务的原子...
- **PROPAGATION_REQUIRED**:这是最常用的事务传播行为,如果当前存在事务,则当前方法将在该事务中运行;如果当前不存在事务,则会创建一个新的事务,并在该事务中运行当前方法。这种方式非常适合于那些可能在事务...
1. **PROPAGATION_REQUIRED**:这是最常用的行为,如果当前存在事务,那么方法将在该事务中执行;如果不存在,则会创建一个新的事务。 2. **PROPAGATION_SUPPORTS**:如果当前存在事务,那么方法会在事务环境下执行...
例如,PROPAGATION_REQUIRED适合大部分需要事务控制的操作,而PROPAGATION_REQUIRES_NEW常用于需要独立事务环境的操作,比如发邮件、记录日志等。PROPAGATION_NESTED则用于需要部分独立事务的场景,它允许在保持现有...
1. PROPAGATION_REQUIRED:如果存在一个事务,则支持当前事务。如果没有事务则开启新的事务。 2. PROPAGATION_SUPPORTS:如果存在一个事务,支持当前事务。如果没有事务,则非事务的执行。 3. PROPAGATION_MANDATORY...
如果当前没有事务,则执行与PROPAGATION_REQUIRED类似的操作。 - **适用场景**:适用于需要在现有事务中创建嵌套事务的情况,例如需要回滚部分操作但不影响整个外部事务的完整性的场景。 - **注意**:使用...
例如,一个PROPAGATION_REQUIRED的方法调用了一个PROPAGATION_REQUIRES_NEW的方法,那么第二个方法将在新的独立事务中执行,即使第一个方法已经在一个事务中。 SSH,通常指的是Spring、Struts和Hibernate三个开源...
Spring定义了七种事务传播行为:PROPAGATION_REQUIRED、PROPAGATION_SUPPORTS、PROPAGATION_MANDATORY、PROPAGATION_REQUIRES_NEW、PROPAGATION_NOT_SUPPORTED、PROPAGATION_NEVER和PROPAGATION_NESTED。每种行为都...
1. **PROPAGATION_REQUIRED**:这是默认的传播行为,表示如果当前存在事务,则加入该事务;如果不存在,则创建一个新的事务。这也是最常用的模式。 2. **PROPAGATION_SUPPORTS**:如果当前存在事务,那么运行在该...
如果当前没有事务,其行为类似于PROPAGATION_REQUIRED。嵌套事务的特点是它可以回滚到特定的保存点,这样就可以部分回滚外层事务,而不会影响其他部分。 了解这些传播行为后,开发者可以根据业务需求选择合适的事务...
-- 配置拦截器,定义事务规则 --> *">PROPAGATION_REQUIRED,readOnly *">PROPAGATION_REQUIRED,-Exception *">PROPAGATION_REQUIRED,-Exception *">PROPAGATION_REQUIRED,-Exception <!-- 配置目标对象...
1. **PROPAGATION_REQUIRED**:这是默认的传播行为,如果当前存在事务,则加入该事务;如果当前没有事务,则创建一个新的事务。这是最常见的选择。 2. **PROPAGATION_SUPPORTS**:如果当前存在事务,那么运行在该...
如果当前没有事务,则行为类似于`PROPAGATION_REQUIRED`。嵌套事务允许子事务在主事务中回滚,而不会影响主事务之外的操作。 ```java @Transactional(propagation = Propagation.REQUIRED) public void methodA() { ...
例如,PROPAGATION_REQUIRED 表示如果当前存在事务,则加入到当前事务;如果没有,则创建一个新的事务。 此外,Spring 事务管理还涉及到事务隔离级别(如 READ_UNCOMMITTED、READ_COMMITTED、REPEATABLE_READ、...
- **PROPAGATION_REQUIRED**:如果当前存在事务,则加入该事务;如果当前没有事务,则创建一个新的事务。 - **PROPAGATION_MANDATORY**:如果当前存在事务,则加入该事务;如果当前没有事务,则抛出异常。 - **...
1. `PROPAGATION_REQUIRED`: 这是最常见的事务传播行为,表示如果当前存在事务,那么方法将在这个事务中运行;如果当前不存在事务,则创建一个新的事务。如果在方法执行过程中发生异常,那么事务会被回滚,否则在...