一、事务
1、事务的介绍
事务就是用户定义的一系列执行SQL语句的操作, 这些操作要么完全地执行,要么完全地都不执行, 它是一个不可分割的工作执行单元。
2、事务的使用场景
例如在日常生活中,有时我们需要进行银行转账,这个银行转账操作背后就是需要执行多个SQL语句,假如这些SQL执行到一半突然停电了,那么就会导致这个功能只完成了一半,这种情况是不允许出现的,要想解决这个问题就需要通过事务来完成。
二、事务的四大特性
原子性(Atomicity)
要么都执行,要么都不执行一致性(Consistency)
事务前后的数据都是正确的隔离性(Isolation)
事物之间相互隔离,互不干扰(并发执行的事务彼此无法看到对方的中间状态)持久性(Durability)
事务一旦提交不可再回滚
三、Spring中事务控制的API
PlatformTransactionManager接口是spring的事务管理器,它里面提供了我们常用的操作事务的方法
public interface PlatformTransactionManager { //开启事务 TransactionStatus getTransaction(TransactionDefinition definition) throws TransactionException; //提交事务void commit(TransactionStatus status) throws TransactionException; //回滚事务void rollback(TransactionStatus status) throws TransactionException;
}
TransactionDefinition接口 定义事务的属性
//传播行为int getPropagationBehavior();//隔离级别int getIsolationLevel();//事务超时int getTimeout();//是否只读boolean isReadOnly();
四、事务的隔离级别
隔离级别 | 是否脏读 | 是否不可重复度 | 是否幻读 |
---|---|---|---|
ISOLATION_DEFAULT | x | x | √ |
ISOLATION_READ_UNCOMMITTED | √ | √ | √ |
ISOLATION_READ_COMMITTED | x | √ | √ |
ISOLATION_REPEATABLE_READ | x | x | √ |
ISOLATION_SERIALIZABLE | x | x | x |
问题 | 描述 | 隔离级别 |
---|---|---|
脏读 | 一个事务读取到另一个事务还未提交的数据 | read-commited |
不可重复读 | 一个事务内多次读取一行数据的内容,其结果不一致 | repeatable-read |
幻读 | 一个事务内多次读取一张表中的内容,其结果不一致 | serialized-read |
五、事务的传播行为
事务传播行为(propagation behavior)指的就是当一个事务方法被另一个事务方法调用时,这个事务方法应该如何进行。methodA事务方法调用methodB事务方法时,methodB是继续在调用者methodA的事务中运行呢,还是为自己开启一个新事务运行,这就是由methodB的事务传播行为决定的。
Spring中事务的七种传播行为
事务传播行为类型 | 说明 |
---|---|
PROPAGATION_REQUIRED | 如果当前没有事务,就新建一个事务,如果已经存在一个事务中,加入到这个事务中。这是最常见的选择。 |
PROPAGATION_SUPPORTS | 支持当前事务,如果当前没有事务,就以非事务方式执行。 |
PROPAGATION_MANDATORY | 使用当前的事务,如果当前没有事务,就抛出异常。 |
PROPAGATION_REQUIRES_NEW | 无论当前是否存在事务,都新建事务,如果当前存在事务,把当前事务挂起。新事务结束后再恢复旧事务。 |
PROPAGATION_NOT_SUPPORTED | 以非事务方式执行操作,如果存在事务则暂停该事务直到方法执行完毕。 |
PROPAGATION_NEVER | 以非事务方式执行,如果当前存在事务,则抛出异常。 |
PROPAGATION_NESTED | 如果当前存在事务,则在嵌套事务内执行,即子事务。如果当前没有事务,则其行为如同PROPAGATION_REQUIRED ,会新建一个事务。 |
1是默认的事务传播行为(加入事务,要么全部回滚,要么全部执行)
4中,如果原来的事务中发生异常,新建事务没有异常,原来的事务会回滚,新建事务会执行
7是嵌套在事务内执行,也是要么回滚,要么全部执行,只不过和1的执行方式不同
六、事务的回滚规则
rollbackOn
回滚规则,可省略或设置 rollbackOn="Exception",
可省略:运行时异常回滚,编译时异常不回滚
-
如果事务中抛出 RuntimeException,则自动回滚
-
如果事务中抛出 CheckException,不会自动回滚