一、事务定义:

  事务指逻辑上的一组操作,这组操作要么全部成功,要么全部失败.

  二、事务的特性:

  1. 原子性 - 指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。

  2. 一致性 - 指事务前后的数据的完整性必须保持一致。

  3. 隔离性 - 指多个用户并发访问数据库时,一个用户的事务不能被其他用户的事务所干扰,多个并发事务之间数据要互相隔离。

  4. 持久性 - 指一个事务一旦被提交,它对数据库中数据的改变就是永久性的,即使数据库发生故障也不应该对其有任何影响。

  三、Spring事务管理高层抽象主要包括三个接口:

  (1)PlatformTransactionManager:事务管理器

  (2)TransactionDefinition:事务定义信息(事务隔离级别、传播行为,超时,只读),TransactionDefinition的实现类保存了对事务管理的配置信息,该类的实例被Manager读取用来创建执行事务管理的对象;

  (3)TransactionStatus:事务具体运行状态

  四、Spring为不同的持久化框架提供了不同PlatformTransactionManager接口实现

  1. org.springframework.jdbc.datasource.DataSourceTransactionManager —— 在使用Spring JDBC或iBatis进行持久化数据时使用

  2. org.springframework.orm.hibernate3.HibernateTransactionManager —— 在使用Hibernate3.0版本进行持久化数据时使用

  3. org.springframework.orm.jpa.JpaTransactionManager —— 在使用JPA进行持久化时使用

  4. org.springframework.jdo.JdoTransactionManager —— 当持久化机制是jdo时使用

  5. org.springframework.transaction.jta.JtaTransactionManager —— 使用一个JTA实现来管理事务,在一个事务跨越多个资源时必须使用

  事务如果不考虑隔离性,会引发脏读、不可重复读、幻读等问题

  脏读:

  一个事务读取到另一个事务还没有提交的数据,如果这些数据被回滚,则读取到的数据是无效的。

  不可重复读:

  在同一个事务中,多次读取同一数据,读到了另一个事务已经更新的数据,导致返回的结果有所不同。

  虚读,幻读:

  一个事务读取几行记录后,另一个事务插入一些记录,幻读就发生了,在后来的查询中,第一个事务就会发现原来没有的记录。

  五、Spring事务的隔离级别

  1. DEFAULT : 使用后端数据库默认的隔离级别(spring中的选择项)

  2. READ_UNCOMMITTED : 允许你读取还没有提交的改变了的数据,可能会导致脏读、幻读、不可重复读

  3. READ_COMMITTED : 允许在并发事务已经提交后读取数据,可以防止脏读,但幻读和不可重复读仍可能发生

  4. REPEATABLE_READ : 对相同字段的多次读取是一致的,除非数据被事务本身改变。可以防止脏读、不可重复读,但是幻读仍可能发生

  5. SERIALIZABLE : 最高隔离级别,它完全服从ACID的隔离级别,确保不发生脏读、幻读、不可重复读。这在所有的隔离级别中是最慢的,它是典型的通过完全锁定在事务中涉及的数据表来完成的

  MySql默认的事务隔离级别为REPEATABLE_READ

  Oracle默认的事务隔离级别为READ_COMMITTED

  六、Spring事务的传播行为

  事务传播行为要解决的问题:解决业务层方法之间相互调用的问题

  业务层中添加了事务的多个方法被一起调用时,如何处理各方法间事务的关系的问题,具体来说是事务如何传递的问题。

  事务传播行为级别

  1. PROPAGATION_REQUIRED : 支持当前事务,如果不存在就新建一个

  2. PROPAGATION_SUPPORTS : 支持当前事务,如果不存在,就不使用事务

  3. PROPAGATION_MANDATORY : 支持当前事务,如果不存在,抛出异常

  4. PROPAGATION_REQUIRES_NEW : 如果有事务存在,挂起当前事务,创建一个新的事务

  5. PROPAGATION_NOT_SUPPORTED : 以非事务方式运行,如果有事务存在,挂起当前事务

  6. PROPAGATION_NEVER : 以非事务运行,如果有事务存在,抛出异常

  7. PROPAGATION_NESTED : 如果当前事务存在,则嵌套事务执行

  (1). 支持当前事务,即事务存在则加入当前事务,如果事务不存在分别有新建一个事务,不使用事务,抛出异常三种行为;

  (2). 不支持当前事务,即独立运行事务,如果事务存在分别有新建一个事务,不使用事务,抛出异常三种行为;

  (3). 如果当前事务存在,则将自身的事务作为当前事务的子事务运行,在运行子事务时,当前事务记录一个保存点,子事务不报错则和当前事务一起提交或回滚,子事务报错则根据自定义配置让当前事务回滚到保存点或起始点;

  TransactionStatus接口用来记录事务的状态 ,该接口定义了一组方法,用来获取或判断事务的相应状态信息.

  平台事务管理器(PlatformTransactionManager)会根据TransactionDefinition中定义的事务信息(包括隔离级别、传播行为)来进行事务的管理,在管理的过程中事务可能产生了保存点或事务是新的事务等情况,那么这些信息都会记录在TransactionStatus的对象中.

  七、Spring将事务管理分成了两类:

  (1)编程式事务管理

  手动编写代码进行事务管理.(很少使用)

  (2)声明式事务管理:

  基于TransactionProxyFactoryBean的方式.(很少使用)

  需要为每个进行事务管理的类,配置一个TransactionProxyFactoryBean进行增强.

  基于AspectJ的XML方式.(经常使用)

  一旦配置好之后,类上不需要添加任何东西

  基于注解方式.(经常使用)

  配置简单,需要在业务层上添加一个@Transactional的注解.

  

简说Spring事务的更多相关文章

  1. mybatis+spring事务

    http://www.mybatis.org/spring/zh/transactions.html 第四章 事务 一个使用 MyBatis-Spring 的主要原因是它允许 MyBatis 参与到 ...

  2. Spring事务管理总结

    本文是对慕课网上"搞定SSM开发"路径的系列课程的总结,详细的项目文档和课程总结放在github上了.点击查看 本文对应慕课网上课程Spring事务管理,详情可查看:点我 1: 概 ...

  3. spring事务探索

    spring自建事务管理模块.而且这个事务管理是一个抽象设计,可以应用到很多场合,包括普通的DataSource,jta,jms和hibernate上.  要正确使用spring的事务,首先需要了解s ...

  4. 透彻理解Spring事务设计思想之手写实现

    前言 事务,是描述一组操作的抽象,比如对数据库的一组操作,要么全部成功,要么全部失败.事务具有4个特性:Atomicity(原子性),Consistency(一致性),Isolation(隔离性),D ...

  5. 理解 Spring 事务原理

    转载:https://www.jianshu.com/p/4312162b1458 一.事务的基本原理 Spring事务的本质其实就是数据库对事务的支持,没有数据库的事务支持,spring是无法提供事 ...

  6. Spring事务管理的一些注意点

    在<Spring Boot事务管理(下)>中,已经介绍了如果在 protected.private 或者默认可见性的方法上使用@Transactional,事务将是摆设,也不会抛出任何异常 ...

  7. java面试记录二:spring加载流程、springmvc请求流程、spring事务失效、synchronized和volatile、JMM和JVM模型、二分查找的实现、垃圾收集器、控制台顺序打印ABC的三种线程实现

    注:部分答案引用网络文章 简答题 1.Spring项目启动后的加载流程 (1)使用spring框架的web项目,在tomcat下,是根据web.xml来启动的.web.xml中负责配置启动spring ...

  8. spring事务概念理解

    1.数据并发问题 脏读 A事务读取B事务尚未提交的更新数据,并在此数据的基础上操作.如果B事务回滚,则A事务读取的数据就是错误的.即读取了脏数据或者错误数据. 不可重复组 A事务先后读取了B事务提交[ ...

  9. 【Java EE 学习 52】【Spring学习第四天】【Spring与JDBC】【JdbcTemplate创建的三种方式】【Spring事务管理】【事务中使用dbutils则回滚失败!!!??】

    一.JDBC编程特点 静态代码+动态变量=JDBC编程. 静态代码:比如所有的数据库连接池 都实现了DataSource接口,都实现了Connection接口. 动态变量:用户名.密码.连接的数据库. ...

随机推荐

  1. iOS UI基础-6.0 UIActionSheet的使用

    UIActionSheet是在iOS弹出的选择按钮项,可以添加多项,并为每项添加点击事件. 使用 1.需要实现UIActionSheetDelegate  协议 @interface NJWisdom ...

  2. linux 启动引导流程

    课程大纲: Linux引导流程 Linux运行级别 Linux启动服务管理 GRUB配置与应用 启动故障分析与解决 系统引导流程 1.固件firmware(CMOS(固化在硬件上的程序与硬件统称)/B ...

  3. VS2010/MFC编程入门之四十九(图形图像:CDC类及其屏幕绘图函数)

    上一节中鸡啄米讲了文本输出的知识,本节的主要内容是CDC类及其屏幕绘图函数. CDC类简介 CDC类是一个设备上下文类. CDC类提供了用来处理显示器或打印机等设备上下文的成员函数,还有处理与窗口客户 ...

  4. Trove系列(一)—入门篇

    概述DBaaS是目前云计算服务的重要部分,数据库作为一种特殊的应用程序,在应用中普遍存在.而其独特性不仅在于普遍性,而且其性能对应用的表现是至关重要的.数据库的通用性和重要性使得维护一个健壮的数据库实 ...

  5. 无法在web服务器下启动调试。该Web服务器未及时响应

    下午在运行项目的时候,突然出现了以下错误: 无法在web服务器上启动调试.该Web服务器未及时响应.可能是因为另一个调试器已连接到该Web服务器. 搜索了很久才找到这个解决方案: 1:Web.conf ...

  6. Python实现在给定整数序列中找到和为100的所有数字组合

    摘要:  使用Python在给定整数序列中找到和为100的所有数字组合.可以学习贪婪算法及递归技巧. 难度:  初级 问题 给定一个整数序列,要求将这些整数的和尽可能拼成 100. 比如 [17, 1 ...

  7. 能让程序做的事情坚决不用人来做——批量修复markdownlint MD034警告

    欢迎和大家交流技术相关问题: 邮箱: jiangxinnju@163.com 博客园地址: http://www.cnblogs.com/jiangxinnju GitHub地址: https://g ...

  8. ORA-00980: 同义词转换不再有效

    客户账号TB在操作软件时,报错:“[Microsoft][ODBC driver for Oracle][Oracle]ORA-00980: 同义词转换不再有效”. 使用拥有dba权限的账号sys的登 ...

  9. oracle计算过程执行时间写法

    --在oracle写过程中很多是对数据处理,业务比较繁琐,有的需要结合job定时器使用,这样就需要知道执行过程的大概时间,不废话直接上脚本,统计单位为分钟 PROCEDURE DATA_DEAL_WI ...

  10. SQL学习之SQL注入总结

    Sql注入定义: 就是通过把sql命令插入到web表单提交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行的sql命令的目的. sql注入分类: 基于联合查询 基于错误回显 基于盲注,分时间盲 ...