美文网首页
Spring事务@Transactional

Spring事务@Transactional

作者: ggmack | 来源:发表于2019-03-15 15:09 被阅读0次

    一、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配置

    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 图6.2

    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;


    相关文章

      网友评论

          本文标题:Spring事务@Transactional

          本文链接:https://www.haomeiwen.com/subject/knokmqtx.html