Spring传播机制-Propagation.REQUIRED

看网上大部分说法都是“如果存在一个事务,则支持当前事务。如果没有事务则开启”
真是一脸懵逼。。。
最开始我的理解是,如果调用save方法,执行到userMapper.save的时候会开启一个事务,这时候如果该事务未结束,又来请求
会导致第二次调用save不会开启新的事务
然后我测试
http://localhost:9082/coffee.controller/update?phone=15210712345
http://localhost:9082/coffee.controller/update?phone=15210712346
http://localhost:9082/coffee.controller/update?phone=15210712347
第三个请求的时候回滚,本来以为是同一个事务,然后所有的save操作都回滚,结果发现并不是这样的,只有第三个请求回滚了
说明在不嵌套的情况下
每次调用方法save都重新开启一个事务

@Transactional(propagation = Propagation.REQUIRED)
    @Override
    public void save(UserRecord userParam) {
        logger.info("开始执行 save {}, {}", userParam.getId(), userParam.getPhone());
        userMapper.save(userParam);
        try {
            logger.info("save 完成---数据库中的值为 {} 开始 sleep", userParam.getId());
            if ("15210712347".equals(userParam.getPhone())) {
                throw new RuntimeException();
            }
            Thread.sleep(1000 * 10);
            logger.info("sleep结束");
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
2017-12-23 21:15:38 [http-nio-9082-exec-7] INFO  c.c.service.impl.UserServiceImpl2 - 开始执行 save null, 15210712345
2017-12-23 21:15:38 [http-nio-9082-exec-7] DEBUG org.mybatis.spring.SqlSessionUtils - Creating a new SqlSession
2017-12-23 21:15:38 [http-nio-9082-exec-7] DEBUG org.mybatis.spring.SqlSessionUtils - Registering transaction synchronization for SqlSession 
## 第一个请求开启了一个新事务
[org.apache.ibatis.session.defaults.DefaultSqlSession@30bcad12]
2017-12-23 21:15:38 [http-nio-9082-exec-7] DEBUG o.m.s.t.SpringManagedTransaction - JDBC Connection [com.mysql.jdbc.JDBC4Connection@458059db] will be managed by Spring
2017-12-23 21:15:38 [http-nio-9082-exec-7] DEBUG org.mybatis.spring.SqlSessionUtils - Releasing transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@30bcad12]
2017-12-23 21:15:38 [http-nio-9082-exec-7] INFO  c.c.service.impl.UserServiceImpl2 - save 完成---数据库中的值为 null 开始 sleep
## 第二个请求进来了,
2017-12-23 21:15:40 [http-nio-9082-exec-1] INFO  c.c.service.impl.UserServiceImpl2 - 开始执行 save null, 15210712346
2017-12-23 21:15:40 [http-nio-9082-exec-1] DEBUG org.mybatis.spring.SqlSessionUtils - Creating a new SqlSession
## 又开启了一个新的事务,此事务与REQUIRES_NEW不同的是,不会挂起(即不会等到第一个事务执行完成以后才执行),
2017-12-23 21:15:40 [http-nio-9082-exec-1] DEBUG org.mybatis.spring.SqlSessionUtils - Registering transaction synchronization for SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@4c4d91be]
2017-12-23 21:15:40 [http-nio-9082-exec-1] DEBUG o.m.s.t.SpringManagedTransaction - JDBC Connection [com.mysql.jdbc.JDBC4Connection@5f424dee] will be managed by Spring
2017-12-23 21:15:40 [http-nio-9082-exec-1] DEBUG org.mybatis.spring.SqlSessionUtils - Releasing transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@4c4d91be]
2017-12-23 21:15:40 [http-nio-9082-exec-1] INFO  c.c.service.impl.UserServiceImpl2 - save 完成---数据库中的值为 null 开始 sleep
## 第二个事务已经开启,开始sleep
2017-12-23 21:15:48 [http-nio-9082-exec-7] INFO  c.c.service.impl.UserServiceImpl2 - sleep结束
## 第一个事务 开始提交
2017-12-23 21:15:48 [http-nio-9082-exec-7] DEBUG org.mybatis.spring.SqlSessionUtils - Transaction synchronization committing SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@30bcad12]
2017-12-23 21:15:48 [http-nio-9082-exec-7] DEBUG org.mybatis.spring.SqlSessionUtils - Transaction synchronization deregistering SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@30bcad12]
2017-12-23 21:15:48 [http-nio-9082-exec-7] DEBUG org.mybatis.spring.SqlSessionUtils - Transaction synchronization closing SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@30bcad12]
## 第一个事务deregistering 然后close
2017-12-23 21:15:50 [http-nio-9082-exec-1] INFO  c.c.service.impl.UserServiceImpl2 - sleep结束
## 下面执行第二个事务,同第一个事务一致
2017-12-23 21:15:50 [http-nio-9082-exec-1] DEBUG org.mybatis.spring.SqlSessionUtils - Transaction synchronization committing SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@4c4d91be]
2017-12-23 21:15:50 [http-nio-9082-exec-1] DEBUG org.mybatis.spring.SqlSessionUtils - Transaction synchronization deregistering SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@4c4d91be]
2017-12-23 21:15:50 [http-nio-9082-exec-1] DEBUG org.mybatis.spring.SqlSessionUtils - Transaction synchronization closing SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@4c4d91be]

你可能感兴趣的:(Spring)