spring在TransactionDefinition接口中定义了七个事务传播行为:
-
propagation_requierd:如果当前没有事务,就新建一个事务,如果已存在一个事务中,加入到这个事务中,这是最常见的选择。
-
propagation_required_new:新建事务,如果当前存在事务,把当前事务挂起。
- propagation_supports:支持当前事务,如果没有当前事务,就以非事务方法执行。
- propagation_mandatory:使用当前事务,如果没有当前事务,就抛出异常。
- propagation_not_supported:以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。
- propagation_never:以非事务方式执行操作,如果当前事务存在则抛出异常。
- propagation_nested:如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行与propagation_required类似的操作
数据库的事务并发问题:
脏读 TX1将数据从20改为30. TX2读取数据30. 但是TX1 回滚,值变为20 。这是TX2读取到的30就是无效值。
不可重复读 TX1读取值为20. TX2将其改为30. TX1再次读取值为30,和第一次读取不一致。
幻读 TX1读取了表中的一些数据。TX2插入了一些数据。TX1发现多了一些行。
事务的隔离级别
读未提交 允许TX2读取TX1未提交值
读已提交 TX1只能读取到TX2已经提交的更改
可重复读 在读的时候,防止其它事务对这个字段进行更改(mysql默认)
串行化