首先我们回顾一下什么是事务?
事务指的是逻辑上的一组操作,这组操作要么全部成功,要么全部失败。
事务的特性:
原子性、一致性、隔离性、持久性。
原子性:指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。
一致性:指事务前后数据的完整性必须保持一致。
隔离性:指多个用户并发访问数据库时,一个用户的事务不能被其他用户的事务所干扰,多个并发事务之间数据要相互隔离
持久性:指一个事务一旦被提交,它对数据库中数据的改变就是永久性的,即使数据库发生故障也不应该对其有任何影响。
事务的7种传播行为:
1.PROPAGATION_REQUIRED :支持当前事务,如果不存在就新建一个
2.PROPAGATION_SUPPORTS :支持当前事务,如果不存在,就不使用事务
3.PROPAGATION_MANDATORY :支持当前事务,如果不存在,抛出异常
4.PROPAGATION_REQUIRES_NEW :如果有事务存在,挂起当前事务,创建一个新的事务
5.PROPAGATION_NOT_SUPPORTED :以非事务方式运行,如果有事务存在,挂起当前的事务
6.PROPAGATION_NEVER :以非事务方式运行,如果有事务存在,抛出异常
7.PROPAGATION_NESTED :如果当前事务存在,则嵌套事务执行
1、2、3是在一个 事务中运行,4、5、6是在不同事务中运行
事务的隔离级别:
DEFAULT : 使用数据库默认的隔离级别
READ_UNCOMMITED : 允许你读取还未提交的改变了的数据,可能导致脏、幻、不可重复读
READ_COMMITTED : 允许在并发事务已经提交后读取。可防止脏读,但幻读和不可重复读仍可发生(Oracle默认)
REPEATABLE_READ : 对相同字段的多次读取是一致的,除非数据被事务本身改变。可防止脏、不可重复读,但幻读仍可能发生。(MySQL默认)
SERIALIZABLE : 完全服从ACID的隔离级别,确保不发生脏、幻、不可重复读。这在所有的隔离级别中是最慢的,它是典型的通过完全锁定在事务中涉及的数据表来完成的。
总结:
Spring 事务管理分两类:
1.编程式事务管理:
手动编写代码进行事务管理。(很少使用)
2.声明式事务管理:
①基于TransactionProxyFactoryBean的方式。(很少使用)
②基于AspectJ的XML方式。(经常使用,一旦配置好之后,类上不需要添加任何东西。清晰明了)
③基于注解方式。(经常使用,配置简单,需要在业务层类上添加一个@Transactional的注解。)