Spring事务管理的三种方式
一 、第一种:全注解声明式事务 Xml代码 复制代码 收藏代码
.<?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:p="http://www.springframework.org/schema/p"
. xmlns:tx="http://www.springframework.org/schema/tx"
. xmlns:aop="http://www.springframework.org/schema/aop"
. xmlns:context="http://www.springframework.org/schema/context"
. xsi:schemaLocation="http://www.springframework.org/schema/beans
. http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
. http://www.springframework.org/schema/tx
. http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
. http://www.springframework.org/schema/aop
. http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
. http://www.springframework.org/schema/context
. http://www.springframework.org/schema/context/spring-context-2.5.xsd"
. default-init-method="init">
.
. <!-- 引入jdbc配置文件 -->
. <context:property-placeholder location="classpath:jdbc.properties" />
.
. <!--创建jdbc数据源 -->
. <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
. <property name="driverClassName" value="${driver}" />
. <property name="url" value="${url}" />
. <property name="username" value="${username}" />
. <property name="password" value="${password}" />
. </bean>
.
. <!-- 创建SqlSessionFactory,同时指定数据源 -->
. <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
. <property name="dataSource" ref="dataSource" />
. <!-- 配置sql映射文件所在位置 注意:默认与mapper类位置相同 -->
. <property name="mapperLocations" value="classpath:sqlmap/*.xml" />
. </bean>
.
. <!-- 配置事务管理器:第一种 全注解声明式事务 -->
. <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
. <property name="dataSource" ref="dataSource" />
. </bean>
. <tx:annotation-driven transaction-manager="transactionManager" />
. <!-- 第一种 结束位置 -->
. <!-- Mapper接口所在包名,Spring会自动查找其下的Mapper -->
. <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
. <property name="basePackage" value="com.xieke.test.mapper" />
. <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
. <!-- 默认情况下会自动注入id=sqlSessionFactory的bean,也可以按上述方式指定sqlSessionFactory -->
. </bean>
.
.</beans> 使用时:在需要事务控制的类上加上@Transactional注解就可以了. 二、第二种:使用tx标签配置的拦截器声明式事务 Xml代码 复制代码 收藏代码
.<?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:p="http://www.springframework.org/schema/p"
. xmlns:tx="http://www.springframework.org/schema/tx"
. xmlns:aop="http://www.springframework.org/schema/aop"
. xmlns:context="http://www.springframework.org/schema/context"
. xsi:schemaLocation="http://www.springframework.org/schema/beans
. http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
. http://www.springframework.org/schema/tx
. http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
. http://www.springframework.org/schema/aop
. http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
. http://www.springframework.org/schema/context
. http://www.springframework.org/schema/context/spring-context-2.5.xsd"
. default-init-method="init">
.
. <!-- 引入jdbc配置文件 -->
. <context:property-placeholder location="classpath:jdbc.properties" />
.
. <!--创建jdbc数据源 -->
. <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
. <property name="driverClassName" value="${driver}" />
. <property name="url" value="${url}" />
. <property name="username" value="${username}" />
. <property name="password" value="${password}" />
. </bean>
.
. <!-- 创建SqlSessionFactory,同时指定数据源 -->
. <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
. <property name="dataSource" ref="dataSource" />
. <!-- 配置sql映射文件所在位置 注意:默认与mapper类位置相同 -->
. <property name="mapperLocations" value="classpath:sqlmap/*.xml" />
. </bean>
.
. <!-- 配置事务管理器:第二种 使用tx标签配置的拦截器声明式事务 -->
. <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
. <property name="dataSource" ref="dataSource" />
. </bean>
. <!-- 配置事务的传播特性 -->
. <tx:advice id="txAdvice" transaction-manager="transactionManager">
. <tx:attributes>
. <tx:method name="add*" propagation="NESTED" />
. <tx:method name="del*" propagation="NESTED" />
. <tx:method name="*" read-only="true" />
. </tx:attributes>
. </tx:advice>
. <!-- 配置事务的切入点 -->
. <aop:config>
. <aop:pointcut id="targetMethod" expression="execution(* com.xieke.test.service.impl.*.*(..))" />
. <aop:advisor advice-ref="txAdvice" pointcut-ref="targetMethod" />
. </aop:config>
. <!-- 第二种 结束结束位置 -->
.
. <!-- Mapper接口所在包名,Spring会自动查找其下的Mapper -->
. <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
. <property name="basePackage" value="com.xieke.test.mapper" />
. <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
. <!-- 默认情况下会自动注入id=sqlSessionFactory的bean,也可以按上述方式指定sqlSessionFactory -->
. </bean>
.
.</beans> 三、 第三种:使用拦截器声明式事务 Xml代码 复制代码 收藏代码
.<?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:p="http://www.springframework.org/schema/p"
. xmlns:tx="http://www.springframework.org/schema/tx"
. xmlns:aop="http://www.springframework.org/schema/aop"
. xmlns:context="http://www.springframework.org/schema/context"
. xsi:schemaLocation="http://www.springframework.org/schema/beans
. http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
. http://www.springframework.org/schema/tx
. http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
. http://www.springframework.org/schema/aop
. http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
. http://www.springframework.org/schema/context
. http://www.springframework.org/schema/context/spring-context-2.5.xsd"
. default-init-method="init">
.
. <!-- 引入jdbc配置文件 -->
. <context:property-placeholder location="classpath:jdbc.properties" />
.
. <!--创建jdbc数据源 -->
. <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
. <property name="driverClassName" value="${driver}" />
. <property name="url" value="${url}" />
. <property name="username" value="${username}" />
. <property name="password" value="${password}" />
. </bean>
.
. <!-- 创建SqlSessionFactory,同时指定数据源 -->
. <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
. <property name="dataSource" ref="dataSource" />
. <!-- 配置sql映射文件所在位置 注意:默认与mapper类位置相同 -->
. <property name="mapperLocations" value="classpath:sqlmap/*.xml" />
. </bean>
.
. <!-- 配置事务管理器:第三种 使用拦截器声明式事务 -->
. <bean id="transactionManager"
. class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
. <property name="dataSource" ref="dataSource" />
. </bean>
. <bean id="transactionInterceptor"
. class="org.springframework.transaction.interceptor.TransactionInterceptor">
. <property name="transactionManager" ref="transactionManager" />
. <!-- 配置事务属性 -->
. <property name="transactionAttributes">
. <props>
. <!-- PROPAGATION_REQUIRED:支持当前事务,如果当前没有事务,则新建一个事务 -->
. <prop key="add*">PROPAGATION_REQUIRED</prop>
. <prop key="del*">PROPAGATION_REQUIRED</prop>
. </props>
. </property>
. </bean>
. <bean class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator">
. <property name="beanNames">
. <list>
. <value>*ServiceImpl</value>
. </list>
. </property>
. <property name="interceptorNames">
. <list>
. <value>transactionInterceptor</value>
. </list>
. </property>
. </bean>
. <!-- 第三种 结束位置 -->
.
. <!-- Mapper接口所在包名,Spring会自动查找其下的Mapper -->
. <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
. <property name="basePackage" value="com.xieke.test.mapper" />
. <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
. <!-- 默认情况下会自动注入id=sqlSessionFactory的bean,也可以按上述方式指定sqlSessionFactory -->
. </bean>
.
.</beans>
Spring事务的传播属性:
下载地址
PROPAGATION_REQUIRED -- 支持当前事务,如果当前没有事务,就新建一个事务。这是最常见的选择。
PROPAGATION_SUPPORTS -- 支持当前事务,如果当前没有事务,就以非事务方式执行。
PROPAGATION_MANDATORY -- 支持当前事务,如果当前没有事务,就抛出异常。
PROPAGATION_REQUIRES_NEW -- 新建事务,如果当前存在事务,把当前事务挂起。
PROPAGATION_NOT_SUPPORTED -- 以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。
PROPAGATION_NEVER -- 以非事务方式执行,如果当前存在事务,则抛出异常。
PROPAGATION_NESTED -- 如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则进行与PROPAGATION_REQUIRED类似的操作。
Spring事务管理的三种方式的更多相关文章
- 事务管理(下) 配置spring事务管理的几种方式(声明式事务)
配置spring事务管理的几种方式(声明式事务) 概要: Spring对编程式事务的支持与EJB有很大的区别.不像EJB和Java事务API(Java Transaction API, JTA)耦合在 ...
- Spring事务管理的四种方式(以银行转账为例)
Spring事务管理的四种方式(以银行转账为例) 一.事务的作用 将若干的数据库操作作为一个整体控制,一起成功或一起失败. 原子性:指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不 ...
- 配置spring事务管理的几种方式(声明式事务)
Spring配置文件中关于事务配置总是由三个组成部分,分别是DataSource.TransactionManager和代理机制这三部分,无论哪种配置方式,一般变化的只是代理机制这部分. DataSo ...
- Spring事务管理之几种方式实现事务(转)
一:事务认识 大家所了解的事务Transaction,它是一些列严密操作动作,要么都操作完成,要么都回滚撤销.Spring事务管理基于底层数据库本身的事务处理机制.数据库事务的基础,是掌握Spring ...
- Spring事务管理之几种方式实现事务
1.事务认识 大家所了解的事务Transaction,它是一些列严密操作动作,要么都操作完成,要么都回滚撤销.Spring事务管理基于底层数据库本身的事务处理机制.数据库事务的基础,是掌握Spring ...
- Spring事务管理的两种方式
参考文档: http://www.iteye.com/topic/1123347 http://blog.csdn.net/lcj8/article/details/2835432 PS:好像还是tx ...
- Spring事务配置的五种方式(转发)
Spring事务配置的五种方式(原博客地址是http://www.blogjava.net/robbie/archive/2009/04/05/264003.html)挺好的,收藏转发 前段时间对Sp ...
- Spring事务配置的五种方式和spring里面事务的传播属性和事务隔离级别
转: http://blog.csdn.net/it_man/article/details/5074371 Spring事务配置的五种方式 前段时间对Spring的事务配置做了比较深入的研究,在此之 ...
- spring生成EntityManagerFactory的三种方式
spring生成EntityManagerFactory的三种方式 1.LocalEntityManagerFactoryBean只是简单环境中使用.它使用JPA PersistenceProvide ...
随机推荐
- 浅谈2D游戏设计模式3 - 冒险地图之美(1)
冒险岛之所以能长久的存在,很大一部分原因是因为它的美工设计的非常的精细,以及独特,那么独特以及美究竟体现在哪些方面呢? 今天我就带大家来分析几幅地图吧. 好吧,我们就拿上面这幅美景来分析吧. 1.阳光 ...
- 2.第一个Struts2程序-HelloWorld程序
1.新建Web Project项目:Study_Struts2 2.新建HelloWordAction.java类 3.复制struts.xml文件到src目录下,配置struts.xml文件内容如下 ...
- VC++6.0文件关联问题的解决方法
最近我的电脑*.c文件关联失败,无法实现双击*.c打开vc++6.0,感觉特别不爽. 在经过自己的琢磨研究后,终于找到了解决方法. 特此分享下,希望可以帮到遇到同样问题的你. 核心内容: 1.& ...
- Command and Query Responsibility Segregation (CQRS) Pattern 命令和查询职责分离(CQRS)模式
Segregate operations that read data from operations that update data by using separate interfaces. T ...
- mybatis入门基础(九)----逆向工程
一.什么是逆向工程 mybaits需要程序员自己编写sql语句,mybatis官方提供逆向工程 可以针对单表自动生成mybatis执行所需要的代码(mapper.java,mapper.xml.po. ...
- 用jquery实现抽奖小程序
用jquery实现抽奖小程序 这些日子,到处都可以看到关于微信小程序的新闻或报到,在博客园中写关于微信小程序的也不少.但是今天我要说的不是微信小程序,而是用简单的jquery写的一个好玩的抽奖小程序. ...
- MapReduce Shuffle过程
MapReduce Shuffle 过程详解 一.MapReduce Shuffle过程 1. Map Shuffle过程 2. Reduce Shuffle过程 二.Map Shuffle过程 1. ...
- C# decimal保留指定的小数位数,不四舍五入
decimal保留指定位数小数的时候,.NET自带的方法都是四舍五入的. 项目中遇到分摊金额的情况,最后一条的金额=总金额-已经分摊金额的和. 这样可能导致最后一条分摊的时候是负数,所以自己写了一个保 ...
- sql语句查询
1. sql语句查询某位数字或者某几位数字开头的数据,字段类型为数字类: %’: 2. sql搜索以4开头和含有李字的数据: select * from wlzbpre_user where real ...
- 【面试大系】PHP程序员的知识盘点
总结下,PHP面试中常见的知识点,以备查漏补缺和不时之用. 1)php面试题之一——PHP核心技术(高级部分)