一,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)。