这是我参与11月更文挑战的第14天,活动详情查看:2021最后一次更文挑战
一、事务简介
事务,简短的说就是一组操作要么全部完成,要么全部不做,绝不允许只做其中的一部分操作。 比如银行转账,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,并且实现者需要支持保存点事务机制 |