关于Spring的事务配置,主要的配置文件如下(使用了C3P0连接池):

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd">
<!--导入外部文件资源-->
<context:property-placeholder location="classpath:db.properties"/>
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="user" value="${jdbc.user}"/>
<property name="password" value="${jdbc.password}"/>
<property name="jdbcUrl" value="${jdbc.jdbcUrl}"/>
<property name="driverClass" value="${jdbc.driverClass}"/>
<property name="initialPoolSize" value="${jdbc.initPoolSize}"/>
<property name="maxPoolSize" value="${jdbc.maxPoolSize}"/>
</bean>
<!--声明事务管理器-->
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
<!--声明事务通知(相当于切面)-->
<tx:advice id="notifier" transaction-manager="txManager">
</tx:advice>
<!--声明事务通知需要通知的方法-->
<aop:config>
<aop:pointcut id="cutId" expression="execution(* *.*(..))"/>
<aop:advisor advice-ref="notifier" pointcut-ref="cutId"/>
</aop:config>
</beans>

除了在XNL文件中配置事务,而且还可以使用@Transaction注解声明式地管理任务,Spring允许使用@Transaction注解来标注事务方法(只能标注公有方法,因为AOP是基于代理机制的)

也可以将@Transaction注解标注在类级别上,那么类中所有的公共方法都会被定义成支持事务处理的。另外为了支持@Transaction注解,还需要在配置文件中启用<tx:annotion-driven>元素,并为之指定事务管理器,如果事务管理器的名字是transactionManager的话,可以省略。

       <context:component-scan base-package="*"/>
<tx:annotation-driven transaction-manager="txManager"/>

事务的传播属性

当事务方法被另一个事务方法调用时,必须指定事务应该如何传播,例如,方法可能继续在现有的事务中运行,也可能开启一个新的事务,并在自己的事务中运行。

Spring制订了7中类型的传播行为:

-REQUIRED   如果有事务在运行,当前的方法就在该事务中运行,否则,就启动一个新的事务,并在自己的事务中运行

-REQUIRED_NEW  必须启动新事务,并在新的事务中运行,并将之前的事务挂起

-SUPPORT    如果有事务在运行,当前方法在这个事务内运行,如果没有,该方法就不在事务中运行

-NOT_SUPPORT  当前的方法不在事务中运行,如果有运行的事务,它将挂起

-MANDATORY   当前方法必须运行在事务内部,如果没有运行的事务,就抛出异常

-NEVER   当前的方法不运行在事务中,如果有运行的事务,就抛出异常

-NESTED   如果有事务在运行,当前的方法就应该在这个事务的嵌套事务内运行,否则,就启动一个事务,并在自己的事务中运行

如下代码:

       <!--声明事务通知(相当于切面)-->
<tx:advice id="notifier" transaction-manager="txManager">
<tx:attributes>
<tx:method name="methodName" propagation="REQUIRES_NEW"/>
</tx:attributes>
</tx:advice>

事务的隔离级别:

从理论上讲,各个事务之间是完全彼此隔离的,以避免并发事务所导致的问题,在实际开发中为了提升性能,事务会以较低的隔离级别运行,事务的隔离级别可以通过隔离事务属性指定

四个事务隔离级别:

DEFAULT:使用底层数据库默认的隔离级别,大多数数据库的默认隔离级别是READ_COMMITED

READ_UNCOMMITTED:允许事务读取未被其它事务提交的变更,脏读,不可重复读和幻读等问题都会出现

READ_COMMITED:只允许事务读取已经被其它事务提交过的变更,可避免脏读,但不可重复读和幻读的问题仍会出现

REPETABLE_READ:确保事务可以从一个字段中读取相同的值,在这个事务的持续期间,禁止其它事务对这个字段进行更新,可以避免脏读和不可重复读,但是幻读的问题仍存在

SERIALIZABLE:确保事务可以从一个表中读取相同的行,在这个事务的持续期间,禁止其它事务对这个表执行输入,更新和删除操作,所有并发问题都可避免,但是性能十分低下。

事务的隔离级别要得到底层数据库引擎的支持,而不是应用框架的支持。

       <!--声明事务通知(相当于切面)-->
<tx:advice id="notifier" transaction-manager="txManager">
<tx:attributes>
<tx:method name="methodName" propagation="REQUIRES_NEW" isolation="READ_COMMITTED"/>
</tx:attributes>
</tx:advice>

设置回滚事务属性:

       <tx:advice id="txRoll" transaction-manager="txManager">
<tx:attributes>
<!--
rollbackFor:遇到时必须进行回滚
noRollbackFor:一组异常类,遇到时不必回滚
上面两个属性的值都是一组异常类,如果有多个异常类,可用逗号或空格分开
-->
<tx:method name="methodName" propagation="REQUIRES_NEW" isolation="READ_COMMITTED"
rollback-for="java.io.IOException,java.sql.SQLTransientException"
no-rollback-for="java.lang.RuntimeException"/>
</tx:attributes>
</tx:advice>

超时和只读属性:

超时属性:事务在回滚之前可以保持多久,这样可以防止长期运行的事务占用资源

只读属性:表示这个事务只读取数据但是不更新数据,这可帮助数据库引擎优化事务

       <tx:advice id="txRoll" transaction-manager="txManager">
<tx:attributes>
<!--
rollbackFor:遇到时必须进行回滚
noRollbackFor:一组异常类,遇到时不必回滚
上面两个属性的值都是一组异常类,如果有多个异常类,可用逗号或空格分开
-->
<tx:method name="methodName" propagation="REQUIRES_NEW" isolation="READ_COMMITTED"
rollback-for="java.io.IOException,java.sql.SQLTransientException"
no-rollback-for="java.lang.RuntimeException"
timeout="30"
read-only="true"
/>
</tx:attributes>
</tx:advice>

  

Sping中的事务配置的更多相关文章

  1. Spring事务配置的五种方式(转载)

    Spring配置文件中关于事务配置总是由三个组成部分,分别是DataSource.TransactionManager和代理机制这三部分,无论哪种配置方式,一般变化的只是代理机制这部分. DataSo ...

  2. Spring事务配置的五种方式

    Spring配置文件中关于事务配置总是由三个组成部分,分别是DataSource.TransactionManager和代理机制这三部分,无论哪种配置方式,一般变化的只是代理机制这部分. DataSo ...

  3. Spring中的事务

    Spring配置文件中关于事务配置总是由三个组成部分,分别是DataSource.TransactionManager和代理机制这三部分,无论哪种配置方式,一般变化的只是代理机制这部分. DataSo ...

  4. 【荐】Spring事务配置的五种方式

    Spring配置文件中关于事务配置总是由三个组成部分,分别是DataSource.TransactionManager和代理机制这三部分,无论哪种配置方式,一般变化的只是代理机制这部分. DataSo ...

  5. spring事务配置详解

    一.前言 好几天没有在对spring进行学习了,由于这几天在赶项目,没有什么时间闲下来继续学习,导致spring核心架构详解没有继续下去,在接下来的时间里面,会继续对spring的核心架构在继续进行学 ...

  6. Spring管理 hibernate 事务配置的五种方式

    Spring配置文件中关于事务配置总是由三个组成部分,DataSource.TransactionManager和代理机制这三部分,无论是那种配置方法,一般变化的只是代理机制这块! 首先我创建了两个类 ...

  7. Spring事务配置

    Spring中事务的配置学习: 1.心法 Spring配置文件中关于事务配置总是由三个组成部分,分别是DataSource.TransactionManager和代理机制这三部分,无论哪种配置方式,一 ...

  8. Spring事务配置的五种方式 -- 越往后需要Spring版本越高

    第五种 基本零配置  个人感觉第四种也可以 Spring配置文件中关于事务配置总是由三个组成部分,分别是DataSource.TransactionManager和代理机制这三部分,无论哪种配置方式, ...

  9. Spring 事务配置的几种方式

    参考:http://www.blogjava.net/robbie/archive/2009/04/05/264003.html http://www.cnblogs.com/appleat/arch ...

随机推荐

  1. BLE链路层状态机

    BLE的Link层,应当是了解BLE需要首先熟悉的一部分,BLE的Controller部分主要都在围绕这一部分实现的.Link层的内容规定了BLE底层是怎么实现蓝牙设备之间的控制,数据传输等等的.Li ...

  2. postgressql安装

    参考文章 FreeBSD10.0下ports安装postgresql9.4-server: http://download.csdn.net/detail/machen_smiling/8425613 ...

  3. 详解 Qt 线程间共享数据(用信号槽方式)

    使用共享内存.即使用一个两个线程都能够共享的变量(如全局变量),这样两个线程都能够访问和修改该变量,从而达到共享数据的目的. Qt 线程间共享数据是本文介绍的内容,多的不说,先来啃内容.Qt线程间共享 ...

  4. git中应用在vs中使用gitignore (转)

    在进行协作开发代码管理的过程中,常常会遇到某些临时文件.配置文件.或者生成文件等,这些文件由于不同的开发端会不一样,如果使用git add . 将所有文件纳入git库中,那么会出现频繁的改动和push ...

  5. 在Windows上一键编译各种版本的Protobuf

    所需工具 : cmake  for  windows 和  git for windows 原理:protobuf 是google的一个开源项目,其源代码在github上可以下载到,并且源码都采用cm ...

  6. TermServDevices错误

    来源TermServDevices的错误日志,日志内容 事类型:     错误 事件来源:     TermServDevices 描述 打印机 XXXX 所需的驱动程序 XXX 未知.登录之前,请与 ...

  7. JavaScript实现进入某一页面时自动将鼠标光标放在某一textbox上

    <script language="javascript" type="text/javascript"> var txtText0 = " ...

  8. JQuery:JQuery捕获HTML

    JQuery:捕获HTML1.jQuery - 获取内容和属性介绍: jQuery 拥有可操作 HTML 元素和属性的强大方法. jQuery 中非常重要的部分,就是操作 DOM 的能力. jQuer ...

  9. 05-雷海林-mysql备份原理与在TDSQL中的实践

    05-雷海林-mysql备份原理与在TDSQL中的实践 下载地址: http://files.cnblogs.com/files/MYSQLZOUQI/05-%E9%9B%B7%E6%B5%B7%E6 ...

  10. Siri开源了,33%的开发者持疑虑态度,你呢?

    33%的中国开发者对Siri 开放持疑虑态度? 目前来说在iOS 10中,Siri API仅仅支持六类应用程序:打车,通讯,照片搜索,支付,网络电话和锻炼.另外还有一个面向汽车制造商的特殊使用案例,让 ...