一,引言
最近本人参加了不少的面试,总结了每家公司必问的几点问题,分别是spring事务(高频),集合(高频),接下来和大家谈谈spring中的事务
二,主题来了,请简单介绍spring支持的常用数据库事务传播属性和事务隔离级别
事务的传播行为:一个方法在运行了一个开启事务的方法中时,当前方法是使用原来的事务还是开启一个新的事务。
事务传播的行为有传播属性指定,Spring定义了7中类传播行为,如下
其重点主要讲讲其中的两个:REQUIRED,REQUIRES_NEW。
开启事务的注解:开启事务的注解:Transactionl
REQUIRED:
如果当前方法中有事务在运行,当前这个方法就是在事务内运行,否则就启动一个新事务,并在自己的事务内运行
如100块钱,同时购买两本60块钱的书,由于是在当前事务中运行, 为了保证事务的原子性,那么两本书购买都同时失败
REQUIRES_NEW:当前方法必须启动新事务,并在它自己的事务内运行,如果有实物运行,应该将它挂起
同上,如果开启一个新的事务,那么可以允许购买一本书,另一本书失败回滚
三、事务的并发问题
假设有两个事物Transactiona,Transactionb并发执行
1,脏读
a将某条记录的AGE的值从20修改为30 b读取了a更新后的值:30 而a就行了回滚,ace恢复到了20 而b读取到的数据就是30,而且是一个无效的值
2,不可重复读
a读取了ace的值为20 b将这个ace的值修改成30 a再次读取ace的值为30,和第一次读取不一致
3,幻读
a读取了表中的一部分数据 b向表中插入了新的行
四 、事物的隔离级别
数据库系统必须具有隔离并发运行各个事务的能力,使他们不会互相影响,避免各种并发问题。
一个事务与其他事务隔离的程度称为隔离级别。sql标准中规定了多种事务的隔离级别,不同的隔离级别对应不同的干扰程度,隔离级别越高,数据一致性越好但并发性弱
1,读未提交(READ UNCOMMITTED) 允许事务a读取事务b未提交的修改 2,读已提交(READ COMMINTTED) 要求事务a只能读取事务b已提交的修改 3,可重复读(REPQATABLE READ) 确保事务a可以多次从一个字段中读取到相同的值,即事务a执行期间 禁止其他事务对该字段进行更新 4,串行化(SERIALIZABLE) 看这个单词,像不像一个序列化 确保事务a可以多次从一个表中读取到相同的行,在事务a中执行期间 禁止其他事务对这个表进行添加,更新,删除操作。可以避免任何并发问题发生, 但是性能低下
五、事务的特征
数据库事务必须具备 ACID 特征。分别表示原子性(Automic),一致性(Consistency),隔离性
(Isolation),持久性(Durability)。
由于之前做过这方面的介绍,可以参考:https://blog.csdn.net/zhenghuishengq/article/details/113749995