一、事务的基本概念
(一)、事务的基本概念
1、事务是什么
- 事务是数据库操作最基本的单元,逻辑上是一组操作,要么都成功,如果一个失败,则所有操作都失败
2、事务的四个特性
- 原子性:事务是数据库逻辑工作单位,过程不可分隔,事务中的个操作,要么都成功,要么都失败
- 一致性:事务执行的结果必须是使数据库从一个状态变到另一个一致性状态,即操作之前和操作之后的总量是一样的
- 隔离性:一个事务的执行不能受其他事务的干扰,即多事务操作时,不会产生影响
- 持久性:也称为永久性,指一个事务一旦提交,它对数据库中的数据的改变就是永久性的。
(二)、事务的几种实现方式
1、基于 TransactionProxyFactoryBean的声明式事务管理
2、基于 @Transactional 的声明式事务管理
3、基于Aspectj AOP配置事务
二、Spring进行事务管理
1、事务是添加到JavaEE三层结构里面的service层上(即业务逻辑层)
2、Spring进行事务管理的两种方式:
- 编程式事务管理
- 声明式事务管理
3、声明式事务管理的两种实现方式
- 基于注解方式
- 基于XML配置文件方式
注意:在Spring进行声明式事务管理时,底层使用AOP原理
4、Spring事务管理的API
(1)、提供了一个接口(即:PlatformTransactionManager接口),代表事务管理器,这个接口针对不同的框架提供不同的实现类
三、声明式事务管理(参数配置)
1、注解**@Transactional**中的相关参数介绍
(1)、propagation(事务的传播行为)
(2)、isolation(事务隔离级别)
- 隔离性,多事物操作之间不会产生影响,不考虑隔离性会产生很多问题
- 常见的三个问题:脏读、不可重复读、虚(幻)读
①、脏读:一个未提交的事务读取到另一个未提交事务的数据
②、不可重复读:一个未提交事务读取到另一个提交事务的修改数据
③、虚读:一个未提交事务读取到一个人提交事务添加的数据 - 解决方案:通过设置事务隔离级别,解决读问题
隔离级别:Mysql中默认REPEATABLEREAD
(3)、timeout(超时时间)
- 事务需要在一定时间内进行提交,如果不提交,就会进行回滚
- 默认值为-1,即不超时,设置时间以秒(s)进行计算
(4)、readOnly(是否只读)
- 读:查询操作
- 写:添加、修改、删除操作
- readOnly默认值为false,表示可以查询,也可以进行添加、修改和删除
- 设置true之后,只能进行查询操作
(5)、rollbackFor(回滚)
- 设置出现哪些异常进行事务回滚
(6)、noRollbackFor(不回滚)
- 设置出现异常时不进行回滚
配置示例代码:
@Service
@Transactional(propagation = Propagation.REQUIRED,isolation = Isolation.REPEATABLE_READ,
timeout = -1,readOnly = false)
public class UserService {