http://blog.csdn.net/yerenyuan_pku/article/details/52886207

前面我们讲解了使用Spring注解方式来管理事务,现在我们就来学习使用Spring配置文件实现事务管理。本文是建立在使用Spring注解方式管理事务与传播行为详解案例基础之上的。 
首先我们在cn.itcast.service.impl包下再新建一个业务bean——PersonServiceBean2.java,其代码为:

/*** 使用JdbcTemplate进行insert/update/delete/select操作* @author li ayun**/
public class PersonServiceBean2 implements PersonService { private JdbcTemplate jdbcTemplate; public void setDataSource(DataSource dataSource) { this.jdbcTemplate = new JdbcTemplate(dataSource); } public void save(Person person) { jdbcTemplate.update("insert into person(name) value(?)", new Object[]{person.getName()}, new int[]{java.sql.Types.VARCHAR}); } public void update(Person person) { jdbcTemplate.update("update person set name=? where id=?", new Object[]{person.getName(), person.getId()}, new int[]{java.sql.Types.VARCHAR, java.sql.Types.INTEGER}); } /** * 使用JdbcTemplate获取一条记录 */ public Person getPerson(Integer personid) { return jdbcTemplate.queryForObject("select * from person where id=?", new Object[]{personid}, new int[]{java.sql.Types.INTEGER}, new PeronRowMapper()); } /** * 使用JdbcTemplate获取多条记录 */ public List<Person> getPersons() { return jdbcTemplate.query("select * from person", new PeronRowMapper()); } public void delete(Integer personid) throws Exception { jdbcTemplate.update("delete from person where id=?", new Object[]{personid}, new int[]{java.sql.Types.INTEGER}); } }
  • 1

由于我们采用的是基于XML方式配置事务,所以Spring配置文件应该改为:

<?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:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx" 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-4.2.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.2.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.2.xsd"> <context:property-placeholder location="classpath:jdbc.properties" /> <!-- classpath: 明确指明jdbc.properties文件是在类路径底下的 --> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${jdbc.driverClassName}" /> <property name="url" value="${jdbc.url}" /> <property name="username" value="${jdbc.username}" /> <property name="password" value="${jdbc.password}" /> <!-- 连接池启动时的初始值 --> <property name="initialSize" value="${jdbc.initialSize}" /> <!-- 连接池的最大值 --> <property name="maxActive" value="${jdbc.maxActive}" /> <!-- 最大空闲值。当经过一个高峰时间后,连接池可以慢慢将已经用不到的连接慢慢释放一部分,一直减少到maxIdle为止 --> <property name="maxIdle" value="${jdbc.maxIdle}" /> <!-- 最小空闲值。当空闲的连接数少于阀值时,连接池就会预申请去一些连接,以免洪峰来时来不及申请 --> <property name="minIdle" value="${jdbc.minIdle}" /> </bean> <bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource" /> </bean> <!-- <tx:annotation-driven transaction-manager="txManager" /> --> <aop:config> <aop:pointcut id="transactionPointcut" expression="execution(* cn.itcast.service..*.*(..))"/> <aop:advisor advice-ref="txAdvice" pointcut-ref="transactionPointcut"/> <!-- Spring提供的事务通知 --> </aop:config> <!-- 代表事务通知的bean,以下配置实际上在Spring容器里面也会注册一个事务(通知)管理器,专门用来做事务处理的bean --> <tx:advice id="txAdvice" transaction-manager="txManager"> <tx:attributes> <tx:method name="get*" read-only="true" propagation="NOT_SUPPORTED"/> <tx:method name="*"/> <!-- 其他方法使用默认的事务传播属性 --> </tx:attributes> </tx:advice> <bean id="personService" class="cn.itcast.service.impl.PersonServiceBean2"> <property name="dataSource" ref="dataSource" /> </bean> </beans>
  • 1

这样,PersonServiceBean2就会受Spring的事务管理。若此时我们将delete()方法的代码修改为:

public void delete(Integer personid) throws Exception {jdbcTemplate.update("delete from person where id=?", new Object[]{personid}, new int[]{java.sql.Types.INTEGER}); jdbcTemplate.update("delete from personsss where id=10"); // sql语句故意写错 }
  • 1

那么以上2条语句将会在同一个事务中执行,要么一起执行成功,要么一起执行失败。如果要是没有基于XML方式配置事务的代码,2条语句都会在各自的事务中执行。

(转)使用Spring配置文件实现事务管理相关推荐

  1. Spring配置文件详解三:Spring声明式事务管理

    1.声明式事务管理 Spring提供了声明式事务管理,这是通过Spring AOP实现的. 原理:Spring中进行事务管理的通常方式是利用AOP(面向切片编程)的方式,为普通java类封装事务控制, ...

  2. Spring中的事务管理详解

    在这里主要介绍Spring对事务管理的一些理论知识,实战方面参考上一篇博文: http://www.cnblogs.com/longshiyVip/p/5061547.html 1. 事务简介: 事务 ...

  3. Spring JDBC-Spring对事务管理的支持

    概述 事务管理关键抽象 Spring事务管理的实现类 Spring JDBC 和MybBatis的事务管理器的配置 JPA的事务管理器的配置 Hibernate的事务管理器的配置 JTA 的事务管理器 ...

  4. Spring(四)——AOP、Spring实现AOP、Spring整合Mybatis、Spring中的事务管理

    文章目录 1. 什么是AOP 2. 使用Spring实现AOP 2.1 使用Spring的API 接口实现 2.2 自定义实现 2.3 使用注解实现 3. 整合MyBatis 3.1 MyBatis- ...

  5. Spring入门5.事务管理机制

    Spring入门5.事务管理机制 20131126 代码下载 : 链接: http://pan.baidu.com/s/1kYc6c 密码: 233t 回顾之前的知识,Spring 最为核心的两个部分 ...

  6. spring声明式事务管理方式( 基于tx和aop名字空间的xml配置+@Transactional注解)

    1. 声明式事务管理分类 声明式事务管理也有两种常用的方式, 一种是基于tx和aop名字空间的xml配置文件,另一种就是基于@Transactional注解. 显然基于注解的方式更简单易用,更清爽. ...

  7. spring事务管理器的作用_【面试必问】Spring中的事务管理详解

    在这里主要介绍Spring对事务管理的一些理论知识,实战方面参考上一篇博文: http://www.cnblogs.com/longshiyVip/p/5061547.html 1. 事务简介: 事务 ...

  8. 基于Spring中的事务管理机制

    什么是事务? 通俗理解,事务其实就是一系列指令的集合. 为什么要使用事务管理? 我们在实际业务场景中,经常会遇到数据频繁修改读取的问题.在同一时刻,不同的业务逻辑对同一个表数据进行修改,这种冲突很可能 ...

  9. 【Spring学习笔记 九】Spring声明式事务管理实现机制

    什么是事务?事务就是把一系列的动作当成一个独立的工作单元,这些动作要么全部完成,要么全部不起作用,关乎数据准确性的地方我们一定要用到事务,防止业务逻辑出错. 什么是事务管理,事务管理对于企业应用而言至 ...

最新文章

  1. linux中LVM动态扩容和管理
  2. 官方剧透:1.11 发版前我们偷看了 Flink 中文社区发起人的聊天记录
  3. tomcat关闭和重启
  4. 流线动态图python_Node.js Stream(流)
  5. Java生成真正格式的Excel文件
  6. 《混合云计算》——2.3 整合势在必行
  7. ServletContextListener 和HttpSessionListener 的自我理解
  8. 基于SSM的大学拍卖网站(含文档)
  9. Springboot 静态资源路径配置 实例介绍
  10. Spring事务同步synchronized一起使用引发的问题
  11. 大富豪5.3全网首发,真正的5.3正版破解授权,不是高防端
  12. 绝地求生+守望先锋?2019首款黑马游戏Apex英雄凭什么如此火爆?
  13. 总不能因为杯子碎了就不再喝水了吧
  14. Windows Server 2019 英文语系更新笔记
  15. 支持向量机(SVM)入门理解与推导
  16. pip升级到最新版本
  17. 做保险,跟对人很重要
  18. 什么时候进行套利交易比较好?
  19. 【数据库专题】“第一幕”——《狗叫江湖》之数据库系统概论(续集)【蒸滴很c】
  20. 《Distilling the Knowledge in a Neural Network》 论文阅读笔记

热门文章

  1. Windows环境 安装dlib cv2(python) 总结
  2. [android] 切换按钮-自定义控件
  3. 为品牌管理增加检索名称和状态项
  4. QT数据库使用案列【联系人】-- 使用sqlite和QStringListModel
  5. Ajax弹出式无刷新城市选择特效
  6. 世界杯决赛不好看,有点像假球,被裁判黑了?
  7. windows十大必禁服务
  8. c++中几种常见的类型转换。int与string的转换,float与string的转换以及string和long类型之间的相互转换。to_string函数的实现和应用。...
  9. 4个月原生weex混合开发终结()
  10. 对LinqtoExcel的扩展 【数据有限性,逻辑有效性】