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的方式运行,即开启一个新的事务