一.事务的隔离级别
1.1 隔离级别
Serializable(串行): 最严格,串行处理,消耗资源大
Repeatable Read(可重复读):保证了一个事务不会修改已经由另一个事务读取但未提交(回滚)的数据
Read Committed(读已提交,不可重复读):大多数主流数据库的默认事务等级
Read Uncommitted(读未提交):保证了读取过程中不会读取到非法数据。
https://blog.csdn.net/u011066470/article/details/121232727
1.2 事务的传播行为
PROPAGATION_REQUIRED--支持当前事务,如果当前没有事务,就新建一个事务,最常见的选择。
PROPAGATION_SUPPORTS--支持当前事务,如果当前没有事务,就以非事务方式执行。
PROPAGATION_MANDATORY--支持当前事务,如果当前没有事务,就抛出异常。
PROPAGATION_REQUIRES_NEW--新建事务,如果当前存在事务,把当前事务挂起, 两个事务之间没有关系,一个异常,一个提交,不会同时回滚
PROPAGATION_NOT_SUPPORTED--以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。
PROPAGATION_NEVER--以非事务方式执行,如果当前存在事务,则抛出异常
二.事务的案例
2.1 正常的逻辑添加
2.2 设置报错逻辑添加
程序报错后,还是执行了新增数据操作,并不是我们期望的。
2.3 设置事务报错逻辑添加
添加事务:@Transactional(propagation=Propagation.REQUIRED)
不停的刷新,数据库,可以看到,报错后,进行事务的控制,不再进行新增加数据了!!
三 多级表之间的事务
报错
2.无法添加进数据