一、Spring事务简介
1. 事务是逻辑处理原子性的保证手段。
2. 事务两个重要特性:传播级别和隔离级别。
3. 支持编程式事务管理和声明式事务管理两种方式。
4. 事务并发一般需要相应的隔离措施,否则就会出现各种数据问题。
二、传播级别propagation
1. REQUIRED:如果当前存在事务,则加入该事务;如果当前没有事务,则创建一个新的事务。这是默认值。
2. REQUIRES_NEW:创建一个新的事务,如果当前存在事务,则把当前事务挂起。
3. SUPPORTS:如果当前存在事务,则加入该事务;如果当前没有事务,则以非事务的方式继续运行。
4. NOT_SUPPORTED:以非事务方式运行,如果当前存在事务,则把当前事务挂起。
5. NEVER:以非事务方式运行,如果当前存在事务,则抛出异常。
6. MANDATORY:如果当前存在事务,则加入该事务;如果当前没有事务,则抛出异常。
7. NESTED:如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行与PROPAGATION_REQUIRED类似的操作。(这个和REQUIRED区别在于一个是加入到一个事务,一个是在嵌套事务运行)
三、隔离级别isolation
1.READ_UNCOMMITTED(读未提交)
2.READ_COMMITTED(读已提交)
3.REPEATABLE_READ(可重复读,MySQL-InnoDB默认隔离级别)
4.SERIALIZABLE(串行化)
四、@Transactional
1. 开启事务配置
a.)SpringBoot: @EnableTransactionManagement
b.)SpringMVC基于xml配置
2. 将@Transactional注释应用于具有公共可见性的方法。如果注释protected,private方法,则@Transactional不会引发错误,但带注释的方法事务配置不会生效。
3. 使用@Transactional注释具体类(以及具体类的方法),而不是注释接口;注释具体类 ,则该类下public方法事务生效。
4. 在代理模式(默认设置)下,只拦截通过代理进入的外部方法调用。目标对象中的方法调用目标对象的另一个方法,事务不会生效,即使调用的方法被标记@Transactional。
5. proxy-target-class属性控制为使用@Transactional注释的类,创建的事务代理类型。如果 proxy-target-class设置为true,则创建基于类的代理。如果 proxy-target-class是false或者省略了属性,则创建基于标准JDK接口的代理。
6. 一个栗子:
6.1:注释 @Transactional的componentOperate()方法里,调用另一个service注释 @Transactional的createLog(),相当于只有@Transactional的componentOperate()方法里事务生效。
6.2:如果想要另一个service注释 @Transactional的createLog()事务生效,则用子事务@Transactional(propagation = Propagation.REQUIRES_NEW)。
五、常用操作命令
1. 命令行,开启事务:
set autocommit=off;
或start transaction;
2. 提交事务:
commit;
3. 设置当前会话隔离级别:
set session transaction isolation level repeatable read;
set session transaction isolation level READ UNCOMMITTED;
set session transaction isolation level READ COMMITTED;
4. 设置系统当前隔离级别:
set global transaction isolation level repeatable read;
5. 查询当前会话隔离级别:
select @@tx_isolation;
6. 查看系统当前隔离级别:
select @@global.tx_isolation;
7. use xx;