Spring事务的一些特性

事务的四大特征

1.原子性:一个事务中全部对数据库的操做是一个不可分割的操做序列,要么全作要么全不作mysql

2.一致性:数据不会由于事务的执行而遭到破坏sql

3.隔离性:一个事物的执行,不受其余事务的干扰,即并发执行的事物之间互不干扰数据库

4.持久性:一个事物一旦提交,它对数据库的改变就是永久的并发

 

五个隔离级别

1.default:默认的事务隔离级别,跟具体的数据有关,mysql默认的事务隔离级别是repeatable_read事务

2.read_uncommitted: 读未提交,一个事务能够感知或者操做另一个未提交的事务,可能会出现脏读、不可重复读、幻读资源

3.read_committed:读已提交,一个事务只能感知或者操做另外一个已经提交的事务,可能会出现不可重复读、幻读it

4.repeatable_read:可重复读,可以避免脏读,不可重复读,不能避免幻读io

4.serializable:串行化,隔离级别最高,消耗资源最低,代价最高,可以防止脏读, 不可重复读,幻读。table

 

七个传播特性

一、Propagation.REQUIRED数据

调用方已经存在事务,则加入到同一个事务中运行,不然,自启一个事务    

二、Propagation.REQUIRES_NEW

不管什么时候自身都会开启新事务

三、Propagation.SUPPORTS

调用方存在事务,则加入到同一个事务中运行,若不存在事务,则以非事务的方式运行

四、Propagation.NOT_SUPPORTED

调用方存在事务,则会被挂起,直到被调用方运行完毕后,事务恢复。

五、Propagation.MANDATORY

调用方存在事务,则加入到同一个事务中运行,若不存在,则抛出异常

六、Propagation.NEVER

调用方存在事务,则抛出异常

七、Propagation.NESTED

若调用方存在事务,则运行一个嵌套事务,若调用方不存在事务,则以Propagation.REQUIRED的方式运行,即开启一个新的事务

相关文章
相关标签/搜索