面试必问之spring事务

一,引言

最近本人参加了不少的面试,总结了每家公司必问的几点问题,分别是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

猜你喜欢

转载自blog.csdn.net/zhenghuishengq/article/details/113924169