spring事务定义
事务是逻辑上的一组操作,组成这组操作的各个逻辑单元,要么一起成功,要么一起失败
事物四大特性
原子性(atomicity):强调事务的不可分割
一致性(consistency):事务的执行的前后数据的完整性保持一致
隔离性(isolation):一个事务执行的过程中,不应该受到其他事务的干扰
持久性(durability):事务一旦结束,数据就持久到数据库
如果不考虑隔离性引发安全性问题
脏读 :一个事务读到了另一个事务的未提交的数据
不可重复读 :一个事务读到了另一个事务已经提交的update的数据导致多次查询结果不一致
虚幻读 :一个事务读到了另一个事务已经提交的 insert 的数据导致多次查询结果不一致
事务隔离级别
1.DEFAULT这是一个PlatfromTransactionManager默认的隔离级别,使用数据库默认的事务隔离 级别.
2.未提交读(read uncommited).脏读,不可重复读,虚读都有可能发生
3.已提交读(read commited):避免脏读。但是不可重复读和虚读有可能发生
4.可重复读(repeatable read):避免脏读和不可重复读.但是虚读有可能发生
5.串行化的(serializable)避免以上所有读问题.
6.Mysql 默认:可重复读
7.Oracle 默认:读已提交
事物的传播机制(PROPAGATION_)
1.REQUIRED:支持当前事务,如果没有事务会创建一个新的事务。
2.SUPPORTS:支持当前事务,如果没有事务的话以非事务方式执行。
3.MANDATORY:支持当前事务,如果没有事务抛出异常。
4.REQUIRES_NEW:创建一个新的事务并挂起当前事务。
5.NOT_SUPPORTED:以非事务方式执行,如果当前存在事务则将当前事务挂起。
6.NEVER:以非事务方式进行,如果存在事务则抛出异常。
7.NESTED:如果当前存在事务,则在嵌套事务内执行,如果当前没有事务,则进行与REQUIRED类 似的操作。