Spring------事务管理(转账)

事务回顾

事务简介

一组业务ABCD操作,要么全部成功,要么全部不成功。

事务特性:ACID

  • 原子性:整体 【原子性是指事务包含的所有操作要么全部成功,要么全部失败】
  • 一致性:数据 【一个事务执行之前和执行之后都必须处于一致性状态】
  • 隔离性:并发 【对于任意两个并发的事务T1T2,在事务T1看来,T2要么在T1开始之前就已经结束,要么在T1结束之后才开始,这样每个事务都感觉不到有其他事务在并发地执行。
  • 持久性:结果 【持久性是指一个事务一旦被提交了,那么对数据库中的数据的改变就是永久性的

 

隔离问题

  • 脏读:一个事务读到另一个事务未提交的内容【读取未提交内容】

在该隔离级别,所有事务都可以看到其他未提交事务的执行结果。本隔离级别很少用于实际应用,因为它的性能也不比其他级别好多少。

 

  • 不可重复读:一个事务读到另一个事务已提交的内容(insert)【读取提交内容】

这是大多数数据库系统的默认隔离级别(但不是MySQL默认的)。它满足了隔离的简单定义:一个事务只能看见已经提交事务所做的改变。

 

  • 虚读(幻读):一个事务读到另一个事务已提交的内容(update)

这是MySQL的默认事务隔离级别,它确保同一事务的多个实例在并发读取数据时,会看到同样的数据行。不过理论上,这会导致另一个棘手的问题:幻读 (Phantom Read)。简单的说,幻读指当用户读取某一范围的数据行时,另一个事务又在该范围内插入了新行,当用户再读取该范围的数据行时,会发现有新的“幻影” 行。

 

  • Serializable(可串行化)

这是最高的隔离级别,它通过强制事务排序,使之不可能相互冲突,从而解决幻读问题。简言之,它是在每个读的数据行上加上共享锁。在这个级别,可能导致大量的超时现象和锁竞争。

隔离级别--解决问题

  • read uncommittd,读未提交。存在3个问题。
  • read committed,读已提交。解决:脏读。存在2个问题。
  • repeatable read ,可重复读。解决:脏读、不可重复读。存在1个问题。
  • serializable,串行化。单事务。没有问题。

Spring------事务管理(转账)

 

 

mysql 事务操作--简单

ABCD 一个事务

Connection conn = null;

try{

  //1 获得连接

  conn = ...;

  //2 开启事务

  conn.setAutoCommit(false);

  A

  B

  C

  D

  //3 提交事务

  conn.commit();

} catche(){

  //4 回滚事务

  conn.rollback();

}

 

mysql 事务操作--Savepoint

 

 

需求:AB(必须),CD(可选)

Connection conn = null;

Savepoint savepoint = null;  //保存点,记录操作的当前位置,之后可以回滚到指定的位置。(可以回滚一部分)

try{

  //1 获得连接

  conn = ...;

  //2 开启事务

  conn.setAutoCommit(false);

  A

  B

  savepoint = conn.setSavepoint();

  C

  D

  //3 提交事务

  conn.commit();

} catche(){

  if(savepoint != null){   //CD异常

     // 回滚到CD之前

     conn.rollback(savepoint);

     // 提交AB

     conn.commit();

  } else{   //AB异常

     // 回滚AB

     conn.rollback();

  }

}

 

1.2 Spring事务管理介绍

1.2.1 Spring提供的事务jar包

transaction = tx

Spring------事务管理(转账)

 

1.2.2 Jar中的三个*接口

Spring------事务管理(转账)

PlatformTransactionManager

平台事务管理器,spring要管理事务,必须使用事务管理器,进行事务配置时,必须配置事务管理器

TransactionDefinition

事务详情(事务定义、事务属性),spring用于确定事务具体详情,

例如:隔离级别、是否只读、超时时间 等

进行事务配置时,必须配置详情。spring将配置项封装到该对象实例。

TransactionStatus

事务状态,spring用于记录当前事务运行状态。例如:是否有保存点,事务是否完成。

spring底层根据状态进行相应操作。

1.2.3 PlatformTransactionManager 事务管理器

先导入两个包

Spring------事务管理(转账)

 

常用的两个事务管理器

Spring------事务管理(转账)

 

1.2.4 TransactionStatus 事务状态

Spring------事务管理(转账)

 

1.2.5 TransactionDefinition

Spring------事务管理(转账)

 

传播行为:在两个业务之间如何共享事务

PROPAGATION_REQUIRED

required , 必须  【默认值】

支持当前事务,A如果有事务,B将使用该事务。

如果A没有事务,B将创建一个新的事务。

PROPAGATION_SUPPORTS

supports ,支持

支持当前事务,A如果有事务,B将使用该事务。

如果A没有事务,B将以非事务执行。

PROPAGATION_MANDATORY

mandatory ,强制

支持当前事务,A如果有事务,B将使用该事务。

如果A没有事务,B将抛异常。

PROPAGATION_REQUIRES_NEW

requires_new ,必须新的

如果A有事务,将A的事务挂起,B创建一个新的事务

如果A没有事务,B创建一个新的事务

PROPAGATION_NOT_SUPPORTED

not_supported ,不支持

如果A有事务,将A的事务挂起,B将以非事务执行

如果A没有事务,B将以非事务执行

PROPAGATION_NEVER

never,从不

如果A有事务,B将抛异常

如果A没有事务,B将以非事务执行

PROPAGATION_NESTED

nested ,嵌套

A和B底层采用保存点机制,形成嵌套事务。

 

掌握:PROPAGATION_REQUIREDPROPAGATION_REQUIRES_NEWPROPAGATION_NESTED

1.3 案例:转帐

        

1.3.1 环境搭建

创建数据库表

create database spring_day3;

use spring_day3;

create table account(

  id int primary key auto_increment,

  username varchar(50),

  money int

);

insert into account(username,money) values('jack','10000');

insert into account(username,money) values('rose','10000');

 

导入jar包    

  1. 核心:4+1
  2. aop : 4 (aop联盟、spring aop、aspectj规范、spring aspect)
  3. 数据库:2  (jdbc/tx)
  4. 驱动:mysql
  5. 连接池:c3p0

Spring------事务管理(转账)

 

 

Dao层

Spring------事务管理(转账)

 

 

Service层

Spring------事务管理(转账)

 

Spring的配置

配置c3p0数据源->dao -> service

Spring------事务管理(转账)

 

测试转帐

Spring------事务管理(转账)

 

1.3.2 手动管理事务【了解】

spring底层使用 TransactionTemplate 事务模板进行操作。

操作

1.service 需要获得 TransactionTemplate

2.spring 配置模板,并注入给service

3.模板需要注入事务管理器

4.配置事务管理器:DataSourceTransactionManager ,需要注入DataSource

 

了解底层即可,因为以后都是通过aop来配置事务

修改Service

Spring------事务管理(转账)

 

修改spring的配置文件

Spring------事务管理(转账)

1.3.3 工厂bean生成代理:半自动

Spring提供 管理事务的代理工厂bean TransactionProxyFactoryBean

 

修改spring配置文件

transactionAttributes:事务详情

prop.key :确定哪些方法使用当前事务配置

    prop.text:用于配置事务详情

    格式:PROPAGATION,ISOLATION,readOnly,-Exception,+Exception

    传播行为    隔离级别         是否只读  异常回滚       异常提交

 

Spring------事务管理(转账)

 

测试:

Spring------事务管理(转账)

 

1.3.4 基本AOP的事务配置【掌握】

Spring的配置文件

Spring------事务管理(转账)

Spring------事务管理(转账)

 

测试同上

 

1.3.5 基本于注解的事务

spring配置

Spring------事务管理(转账)

 

 

Spring------事务管理(转账)

 

 

1.3.5 整合Junit

目的:少写一些代码Spring------事务管理(转账)

导入一个spring-test包

Spring------事务管理(转账)