一、特性
- 原子性:事务中的所有操作要么全部成功,要么全部失败。
- 持久性:事务一旦提交,对数据库的影响就是持久性的。
- 一致性:事务必须使数据库从一个一致性状态转换为另一个一致性状态。也就是事务执行前后状态保持一致。
- 隔离性:多个并发事务之间相互隔离。
二、隔离级别
- 脏读:并发事务之间一个事务读取了另一个事务还未提交的数据。
- 不可重复读:并发事务间一个事务多次读取,分别读取了另一个事务未提交和已经提交的数据,导致多次读取的数据状态不一致。
- 幻读:并发事务间一个事务读取了另一个事务已经提交的数据。与不可重复读的区别是不可重复读前后读取的是同一数据项,而幻读是一批数据。比如前后读取的数据数量不一致。
三、MySQL数据库四大隔离级别
- Serializable(串行化):可避免脏读、不可重复读、幻读的发生。
- Repeatable Read(可重复读):可避免脏读、不可重复读的发生。
- Read Committed(读已提交):可避免脏读的发生。
- Read unCommitted:(读未提交):最低级别,任何情况都会发生。
四、Spring事务管理
- TransactionDefinition.ISOLATION_DEFAULT:这是默认值,表示使用底层数据库的默认隔离级别。对大部分数据库而言,通常这值就是TransactionDefinition.ISOLATION_READ_COMMITTED。
- TransactionDefinition.ISOLATION_READ_UNCOMMITTED:该隔离级别表示一个事务可以读取另一个事务修改但还没有提交的数据。该级别不能防止脏读,不可重复读和幻读,因此很少使用该隔离级别。
- TransactionDefinition.ISOLATION_READ_COMMITTED:该隔离级别表示一个事务只能读取另一个事务已经提交的数据。该级别可以防止脏读,这也是大多数情况下的推荐值。
- TransactionDefinition.ISOLATION_REPEATABLE_READ:该隔离级别表示一个事务在整个过程中可以多次重复执行某个查询,并且每次返回的记录都相同。该级别可以防止脏读和不可重复读。
- TransactionDefinition.ISOLATION_SERIALIZABLE:所有的事务依次逐个执行,这样事务之间就完全不可能产生干扰,也就是说,该级别可以防止脏读、不可重复读以及幻读。但是这将严重影响程序的性能。通常情况下也不会用到该级别。
五、Spring事务的传播行为
- TransactionDefinition.PROPAGATION_REQUIRED:如果当前事务存在,则加入当前事务;如果不存在,则创建一个新的事务。一般默认此项。
- TransactionDefinition.PROPAGATION_REQUIRES_NEW:创建一个新的事务,如果当前事务存在,则挂起当前事务。
- TransactionDefinition.PROPAGATION_SUPPORTS:如果当前存在事务,则加入该事物;如果事务不存在,则以非事务方式执行。
- TransactionDefinition.PROPAGATION_NOT_SUPPORTED:以非事务方式执行,如果当前事务存在,则挂起当前事务。
- TransactionDefinition.PROPAGATION_NEVER:以非事务方式执行,如果存在事务,则抛出异常。
- TransactionDefinition.PROPAGATION_MANDATORY:如果当前存在事务,则加入当前事务;如果不存在,则抛出异常。
- TransactionDefinition.PROPAGATION_NESTED:如果当前存在事务,则创建一个新的事务作为当前事务内嵌事务执行,如果不存在,则取该值等价于TransactionDefinition.PROPAGATION_REQUIRED,即创建一个新的事务。