您的位置:首页 > 其它

事务的传播行为和隔离级别

2015-03-14 12:13 344 查看
事务的传播行为和隔离级别

PROPAGATION_REQUIRED

PROPAGATION_SUPPORTS

PROPAGATION_MANDATORY

PROPAGATION_REQUIRES_NEW

.

一。Spring在TransactionDefinition接口中规定了7种类型的事务传播行为,它们规定了事务方法和事务方法发生嵌套调用时事务如何进行传播:

表1事务传播行为类型

事务传播行为类型说明

1.PROPAGATION_REQUIRED

如果当前没有事务,就新建一个事务,如果已经存在一个事务中,加入到这个事务中。这是最常见的选择。

2.PROPAGATION_SUPPORTS

支持当前事务,如果当前没有事务,就以非事务方式执行。

3.PROPAGATION_MANDATORY

使用当前的事务,如果当前没有事务,就抛出异常。

4.PROPAGATION_REQUIRES_NEW

新建事务,如果当前存在事务,把当前事务挂起。

5.PROPAGATION_NOT_SUPPORTED

以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。

6.PROPAGATION_NEVER

以非事务方式执行,如果当前存在事务,则抛出异常。

7.PROPAGATION_NESTED

如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行与PROPAGATION_REQUIRED类似的操作。

当使用PROPAGATION_NESTED时,底层的数据源必须基于JDBC 3.0,并且实现者需要支持保存点事务机制。

<!--Hibernate事务管理器-->

<bean id="transactionManager"

class="org.springframework.orm.hibernate3.HibernateTransactionManager">

<property name="sessionFactory">

<ref bean="sessionFactory" />

</property>

</bean>

<!-- 定义事务拦截器bean-->

<bean id="transactionInterceptor"

class="org.springframework.transaction.interceptor.TransactionInterceptor">

<!-- 事务拦截器bean需要依赖注入一个事务管理器-->

<property name="transactionManager" ref="transactionManager" />

<property name="transactionAttributes">

<!-- 下面定义事务传播属性-->

<props>

<prop key="save*">PROPAGATION_REQUIRED</prop>

<prop key="find*">PROPAGATION_REQUIRED,readOnly</prop>

<prop key="delete*">PROPAGATION_REQUIRED</prop>

<prop key="update*">PROPAGATION_REQUIRED</prop>

<prop key="*">PROPAGATION_REQUIRED</prop>

</props>

</property>

</bean>

<bean id="managerTemplate" abstract="true" lazy-init="true">

<property name="teamDao">

<ref bean="teamDao" />

</property>

<property name="studentDao">

<ref bean="studentDao" />

</property$amp;>amp;$nbsp;

</bean>

<bean id ="manager" class="com.zd.service.impl.Manager" parent="managerTemplate" />

<!-- 定义BeanNameAutoProxyCreator-->

<bean class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator">

<!-- 指定对满足哪些bean name的bean自动生成业务代理 -->

<property name="beanNames">

<!-- 下面是所有需要自动创建事务代理的bean-->

<list>

<value>manager</value>

</list>

<!-- 此处可增加其他需要自动创建事务代理的bean-->

</property>

<!-- 下面定义BeanNameAutoProxyCreator所需的事务拦截器-->

<property name="interceptorNames">

<list>

<!-- 此处可增加其他新的Interceptor -->

<value>transactionInterceptor</value>

</list>

</property>

</bean>

<!-- 基本数据库操作 -->

<bean id="baseDao" class="com.zd.service.impl.BaseDao">

<property name="hibernateTemplate">

<ref bean="hibernateTemplate"/>

</property>

</bean>

<!-- 班级 -->

<bean id="teamDao" class="com.zd.service.impl.TeamDao">

<property name="baseDao">

<ref bean="baseDao" />

</property>

</bean>

<!-- 学生 -->

<bean id="studentDao" class="com.zd.service.impl.StudentDao">

<property name="baseDao">

<ref bean="baseDao" />

</property>

</bean>

public void testSaveTeam() {

Team team = new Team();

team.setTeamId(DBKeyCreator.getRandomKey(12));

team.setTeamName("Class CCC");

IManager manager = (IManager) SpringContextUtil.getContext().getBean("manager");

Student student = new Student();

student.setStudentId(DBKeyCreator.getRandomKey(13));

student.setSex(Student.SEX_FEMALE);

student.setStudentName("Tom");

student.setTeamId("60FHDXDIG5JQ");

manager.saveTeamAndStu(team, student);

System.out.println("Save Team and Student Success");

二。事务的隔离级别

1、序列化(Serializable):最严格的Spring事务隔离级别,事务串行执行,资源消耗最大; 除了防止脏读,不可重复读外,还避免了幻像读。

2、可重复读取(REPEATABLE READ):保证了一个事务不会修改已经由另一个事务读取但未提交(回滚)的数据。避免了“脏读取”和“不可重复读取”的情况,但是带来了更多的性能损失。 它除了保证一个事务不能读取另一个事务未提交的数据外,还保证了避免下面的情况产生(不可重复读)。

3、授权读取(READ COMMITTED):大多数主流数据库的默认Spring事务隔离等级,保证了一个事务不会读到另一个并行事务已修改但未提交的数据,避免了“脏读取”。该级别适用于大多数系统。 另外一个事务不能读取该事务未提交的数据

4、未授权读取(Read Uncommitted):保证了读取过程中不会读取到非法数据。Spring事务隔离级别在于处理多事务的并发问题。这种隔离级别会产生脏读,不可重复读和幻像读。

  隔离级别越高,越能保证数据的完整性和一致性,但是对并发性能的影响也越大。对于多数应用程序,可以优先考虑把数据库系统的隔离级别设为Read Committed,它能够避免脏读取,而且具有较好的并发性能。尽管它会导致不可重复读、虚读和第二类丢失更新这些并发问题,在可能出现这类问题的个别场合,可以由应用程序采用悲观锁或乐观锁来控制。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: