一、事务简介
事务,简短的说就是一组操作要么全部完成,要么全部不做,绝不允许只做其中的一部分操作。
比如银行转账,A账号转给B账号1000元,其中包括两个操作A-1000、B+1000,要么这两个操作全部完成,要么全部不做,决不允许只执行其中一个操作(你可以想想想如果A-1000,但是B没有+1000会有什么后果?/斜眼笑/斜眼笑)。
事务回滚,当一个事务执行过程中发生了异常、错误,则重新回到最先未开始执行的过程。比如上面那个银行转账过程,假设A-1000操作已经完成,但是在执行B+1000操作时,系统发生位置错误,这时需要回到未执行该转账操作之前的状态,即A、B原来多少钱还是多少钱,一分不能少。
事务提交,当一个事务执行过程没有发生任何异常、错误,这时我们要保存这个事务的修改。比如上面的银行转账过程,假设A-1000、B+1000操作全部完成,没有出现任何异常、错误,这时需要保存事务执行状态修改(A减少了1000元,B增加了1000元),即事务提交。
二、事务的特性(ACID)
事务具有四大特性,如下:
①、原子性(Atomicity):整体 【原子性是指事务包含的所有操作要么全部成功,要么全部失败】
②、一致性(Consistency):数据 【事务提交后的状态合集称为一致,也就是数据库只包含事务提交的状态】
③、隔离性(Isolation):并发 【对于任意两个并发的事务A和B,在事务A看来,B要么在A开始之前就已经结束,要么在A结束之后才开始,这样每个事务都感觉不到有其他事务在并发地执行。】
④、持久性(Durability):结果 【持久性是指一个事务一旦提交了,就保存到硬盘上,对数据库中的数据的改变就是永久性的】
三、五大事务隔离级别
Isolation 属性一共支持五种事务设置,具体介绍如下:
隔离级别
|
解释
|
DEFAULT
|
使用数据库设置的隔离级别 ( 默认 ) ,由 DBA 默认的设置来决定隔离级别 .
|
READ_UNCOMMITTED
|
会出现脏读、不可重复读、幻读 ( 隔离级别最低,并发性能高 )
|
READ_COMMITTED
|
会出现不可重复读、幻读问题(锁定正在读取的行)
|
REPEATABLE_READ
|
会出幻读(锁定所读取的所有行)
|
SERIALIZABLE
|
保证所有的情况不会发生(锁表)
|
四、7大事务传播属性
事务
|
解释
|
PROPAGATION_REQUIRED
|
spring默认的事务传播级别 ,如果存在一个事务,则支持当前事务。如果没有事务则开启一个新的事务。
|
PROPAGATION_SUPPORTS
|
如果存在一个事务,支持当前事务。如果没有事务,则非事务的执行。但是对于事务同步的事务管理器,PROPAGATION_SUPPORTS与不使用事务有少许不同。
|
PROPAGATION_MANDATORY
|
如果已经存在一个事务,支持当前事务。如果没有一个活动的事务,则抛出异常。
|
PROPAGATION_REQUIRES_NEW
|
总是开启一个新的事务。如果一个事务已经存在,则将这个存在的事务挂起。
|
PROPAGATION_NOT_SUPPORTED
|
总是非事务地执行,并挂起任何存在的事务。
|
PROPAGATION_NEVER
|
总是非事务地执行,如果存在一个活动事务,则抛出异常
|
PROPAGATION_NESTED
|
如果一个活动的事务存在,则运行在一个嵌套的事务中. 如果没有活动事务, 则按TransactionDefinition.PROPAGATION_REQUIRED 属性执行,当使用PROPAGATION_NESTED时,底层的数据源必须基于JDBC 3.0,并且实现者需要支持保存点事务机制
|
Spring五个事务隔离级别和七个事务传播行为
Spring的四种事务特性,五种隔离级别,七种传播行为